在做限制input小数点的时候,我本来想通过vue里面的的watch监听来实现, ---实现逻辑是,通过监听输入的内容,当出现"."(点)的时候,记录通过indexOf获取点的位置,然后通过
substring
截取从0位到indexOf获取的点的位置后面几位的数据 . 这样虽然实现了,但是会闪动,会先显示出多一位小数之后再显示想要的小数.
代码是这样的:
integralNum:function(val){
if (val) {
if(val.indexOf(".") != -1){
vm.integralNum = val.substring(0,val.indexOf(".") + 3)
}
}
},
后面通过@input解决了这个闪动, 代码是这样的:
<input id="point_num" type="number" placeholder="积分数量" @input="oninput" value="" οnpaste="" />
oninput:function(e){
e.target.value = (e.target.value.match(/^\d*(\.?\d{0,2})/g)[0]) || null
},