input输入框type=number时的一个缺陷

时间:2021-03-03 08:11:34

本来是在vue里发现获取不到 input[ type="number"]的值,就是输入两个小数点的数值,比如1.1.1,以为是vue的错误,然而不是,vue只做了数字处理

不明白为什么获取不到值还让输入两个小数点呢,这就尴尬了。

//vue里对输入的值做的处理
function toNumber (val) {
var n = parseFloat(val);
return isNaN(n) ? val : n;
}


<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<title>Document</title>
</head> <body>
<div id="app">
      当input的type=number时,当输入的数据有两个小数点的时候,比如1.1.1,此时获取不到this.msg的值
<input type="number" v-model="msg" @input="check">
</div>
<script src="https://cdn.bootcss.com/vue/2.5.17-beta.0/vue.min.js"></script>
<script>
new Vue({
el: '#app',
data: {
msg: '',
},
methods: {
check(val) {
console.log(this.msg, 'this.msg');
}
}
})
</script> </body> </html>

所以呢,输入时数字的时候,可以用input[type="text"],直接用正则验证数值.