Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
uni-app
提交
759b34ea
U
uni-app
项目概览
DCloud
/
uni-app
2 个月 前同步成功
通知
717
Star
38705
Fork
3642
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
7
列表
看板
标记
里程碑
合并请求
1
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
uni-app
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
7
Issue
7
列表
看板
标记
里程碑
合并请求
1
合并请求
1
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
759b34ea
编写于
6月 08, 2021
作者:
D
DCloud_LXH
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat(docs): input组件添加verifyNumber属性
上级
04f0b3fd
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
31 addition
and
14 deletion
+31
-14
docs/component/input.md
docs/component/input.md
+5
-0
src/core/view/components/input/index.vue
src/core/view/components/input/index.vue
+26
-14
未找到文件。
docs/component/input.md
浏览文件 @
759b34ea
...
...
@@ -24,6 +24,7 @@
|adjust-position|Boolean|true|键盘弹起时,是否自动上推页面|App-Android(vue 页面 softinputMode 为 adjustResize 时无效)、微信小程序、百度小程序、QQ小程序|
|hold-keyboard|boolean|false|focus时,点击页面的时候不收起键盘|微信小程序2.8.2|
|auto-blur|boolean|false|键盘收起时,是否自动失去焦点|App 3.0.0+|
|verifyNumber|boolean|false|当设置
`type="number"`
时,是否对输入的字符执行
`当前输入是否有效`
判断|HBuilder 3.1.18+|
|@input|EventHandle||当键盘输入时,触发input事件,event.detail = {value}|差异见下方 Tips|
|@focus|EventHandle||输入框聚焦时触发,event.detail = { value, height },height 为键盘高度|仅微信小程序、App(2.2.3+) 、QQ小程序支持 height|
|@blur|EventHandle||输入框失去焦点时触发,event.detail = {value: value}||
...
...
@@ -36,6 +37,10 @@
-
如果遇到 value 属性设置不生效的问题参考:
[
组件属性设置不生效解决办法
](
/vue-api?id=_4-组件属性设置不生效解决办法
)
-
`input`
组件上有默认的
`min-height`
样式,如果
`min-height`
的值大于
`height`
的值那么
`height`
样式无效。
-
H5 暂未支持动态切换,请使用
`v-if`
进行整体切换。
-
`verifyNumber`
:是否对输入的字符执行输入是否有效判断判断
-
为
`false`
时:不执行输入是否有效判断,输入时会响应
`input`
事件,此时
`event.detail = {value,valid}`
,属性
`valid`
用来表明当前输入是否有效。
-
为
`true`
时:执行输入是否有效判断, 输入非数字字符将不会被赋值,也不会响应
`input`
事件。例如:
`-(负号)`
就是非数字字符。输入负数时,需要输入数字后再移动光标到数字最前面输入
`-(负号)`
。
```
html
<!-- 错误写法 -->
<input
:type=
"isText?'text':'number'"
placeholder=
"请输入内容"
/>
...
...
src/core/view/components/input/index.vue
浏览文件 @
759b34ea
...
...
@@ -94,6 +94,10 @@ export default {
confirmType
:
{
type
:
String
,
default
:
'
done
'
},
verifyNumber
:
{
type
:
Boolean
,
default
:
false
}
},
data
()
{
...
...
@@ -179,20 +183,21 @@ export default {
}
if
(
~
NUMBER_TYPES
.
indexOf
(
this
.
type
))
{
// 在输入 - 负号 的情况下,event.target.value没有值,但是会触发校验 false
,因此做此处理
// 在输入 - 负号 的情况下,event.target.value没有值,但是会触发校验 false
this
.
valid
=
this
.
$refs
.
input
.
validity
&&
this
.
$refs
.
input
.
validity
.
valid
if
(
!
this
.
verifyNumber
)
{
this
.
cachedValue
=
this
.
valueSync
// 处理部分输入法可以输入其它字符的情况
// 上一处理导致无法输入 - ,因此去除
/* if (this.$refs.input.validity && !this.$refs.input.validity.valid) {
}
else
{
// 处理部分输入法可以输入其它字符的情况,此处理无法先输入 -(负号),只能输入数字再移动光标输入负号
if
(
this
.
$refs
.
input
.
validity
&&
!
this
.
valid
)
{
$event
.
target
.
value
=
this
.
cachedValue
this
.
valueSync
=
$event
.
target
.
value
// 输入非法字符不触发 input 事件
return
}
else
{
this
.
cachedValue
=
this
.
valueSync
} */
}
}
}
// type="number" 不支持 maxlength 属性,因此需要主动限制长度。
...
...
@@ -205,9 +210,16 @@ export default {
return
}
}
this
.
$triggerInput
(
$event
,
{
this
.
$triggerInput
(
$event
,
Object
.
assign
({
value
:
this
.
valueSync
},
force
)
},
(()
=>
{
if
(
!
this
.
verifyNumber
)
{
return
{
valid
:
this
.
valid
}
}
})()),
force
)
},
_onComposition
(
$event
)
{
if
(
$event
.
type
===
'
compositionstart
'
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录