Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
uni-app
提交
18a0ea62
U
uni-app
项目概览
DCloud
/
uni-app
3 个月 前同步成功
通知
725
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,发现更多精彩内容 >>
提交
18a0ea62
编写于
11月 27, 2018
作者:
X
xiaoyucoding
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat: 实现 number 类型的 input 支持 maxlength 属性
上级
fd753df8
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
14 addition
and
5 deletion
+14
-5
src/core/view/components/input/index.vue
src/core/view/components/input/index.vue
+14
-5
未找到文件。
src/core/view/components/input/index.vue
浏览文件 @
18a0ea62
...
...
@@ -31,7 +31,7 @@
import
{
emitter
}
from
'
uni-mixins
'
const
TYPES
=
[
'
text
'
,
'
number
'
,
'
idcard
'
,
'
digit
'
,
'
password
'
]
const
INPUT_
TYPES
=
[
'
text
'
,
'
number
'
,
'
idcard
'
,
'
digit
'
,
'
password
'
]
const
NUMBER_TYPES
=
[
'
number
'
,
'
digit
'
]
export
default
{
name
:
'
Input
'
,
...
...
@@ -109,14 +109,14 @@ export default {
type
=
'
number
'
break
default
:
type
=
~
TYPES
.
indexOf
(
this
.
type
)
?
this
.
type
:
'
text
'
type
=
~
INPUT_
TYPES
.
indexOf
(
this
.
type
)
?
this
.
type
:
'
text
'
break
}
return
this
.
password
?
'
password
'
:
type
},
step
()
{
// 处理部分设备中无法输入小数点的问题
return
~
[
'
digit
'
,
'
number
'
]
.
indexOf
(
this
.
type
)
?
'
0.000000000000000001
'
:
''
return
~
NUMBER_TYPES
.
indexOf
(
this
.
type
)
?
'
0.000000000000000001
'
:
''
}
},
watch
:
{
...
...
@@ -130,7 +130,7 @@ export default {
this
.
$emit
(
'
update:value
'
,
value
)
},
maxlength
(
value
)
{
const
realValue
=
this
.
realValue
.
slice
(
0
,
value
)
const
realValue
=
this
.
realValue
.
slice
(
0
,
parseInt
(
value
,
10
)
)
realValue
!==
this
.
inputValue
&&
(
this
.
inputValue
=
realValue
)
}
},
...
...
@@ -195,13 +195,22 @@ export default {
// 处理部分输入法可以输入其它字符的情况
if
(
~
NUMBER_TYPES
.
indexOf
(
this
.
type
))
{
if
(
this
.
$refs
.
input
.
validity
&&
!
this
.
$refs
.
input
.
validity
.
valid
)
{
this
.
inputValue
=
this
.
cachedValue
$event
.
target
.
value
=
this
.
cachedValue
this
.
inputValue
=
$event
.
target
.
value
}
else
{
this
.
cachedValue
=
this
.
inputValue
}
}
// type="number" 不支持 maxlength 属性,因此需要主动限制长度。
if
(
this
.
inputType
===
'
number
'
)
{
const
maxlength
=
parseInt
(
this
.
maxlength
,
10
)
if
(
maxlength
>
0
&&
$event
.
target
.
value
.
length
>
maxlength
)
{
$event
.
target
.
value
=
$event
.
target
.
value
.
slice
(
0
,
maxlength
)
this
.
inputValue
=
$event
.
target
.
value
}
}
this
.
$trigger
(
'
input
'
,
$event
,
{
value
:
this
.
inputValue
})
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录