例子:以下是提现金额时的v-mode
v-mode在 uniapp中的赋值导致渲染问题,具体发生在保留2位小数时发生
这边直接用setTimeout延时赋值解决。这边也能用自定义事件的方式解决就不给出代码了
changeIn(event) {
let mn = event.detail.value
mn = mn.replace(/[^\d\.]/g, ''); //清除“数字”和“.”以外的字符
mn = mn.replace(/\.{2,}/g, '.'); //只保留第一个. 清除多余的
mn = mn.replace(/^(\-)*(\d+)\.(\d\d).*$/, '$1$2.$3'); //保留2位小数
let reg = /(^[1-9]([0-9]*)$|^[0-9]$)/ // 第一位是0, 第二位是数字的情况
if (!reg.test(mn) && mn.indexOf('.') == -1) {
setTimeout(() => {
this.withdrawalmn.val = mn == '' ? '' : 0;
}, 0)
return false
}
// this.withdrawalmn.val = mn;
setTimeout(() => {
this.withdrawalmn.val = mn;
}, 0)
},
<input type="number" v-model="withdrawalmn.val" @input="changeIn" />