uniapp中v-mode 的渲染问题

例子:以下是提现金额时的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" />

版权声明:本文为weixin_43136379原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。