uniapp input输入框,限制金额输入格式

input只能输入数字和小数点,并且只能有一个小数点,小数点前第一位不能为0

html 复制代码
<u-input v-model="submitMoney" border="none" placeholder="请输入提现金额" @input="handleInput" placeholderStyle="color: #ccc;font-size:32rpx;" fontSize="30">
	<u-text text="¥" slot="prefix" margin="0 3px 0 0" bold size="18" color="#ccc"></u-text>
</u-input>
javascript 复制代码
//限制金额输入格式 
handleInput(e) {
	let newValue = e || ''; // 获取输入框的当前值,注意uView的u-input可能通过event.detail传递值
	let lastChar = newValue.slice(-1); // 获取最后一个字符
	let decimalPosition = newValue.indexOf('.'); // 查找小数点的位置
	let integerPart = ''; // 整数部分
	let decimalPart = ''; // 小数部分
	// 如果输入框为空或者只有一个小数点(非法输入),则重置输入框
	if (newValue === '.' || (newValue.length === 1 && lastChar === '.')) {
		newValue = '';
	} else {
		// 分离整数部分和小数部分
		if (decimalPosition !== -1) {
			integerPart = newValue.slice(0, decimalPosition);
			decimalPart = newValue.slice(decimalPosition + 1);
			// 校验小数部分(最多两位数字)
			if (/\D/.test(decimalPart)) {
				decimalPart = decimalPart.replace(/\D/g, ''); // 移除非数字字符
			}
			if (decimalPart.length > 2) {
				decimalPart = decimalPart.slice(0, 2); // 截取前两位数字
			}
			// 重新组装值
			newValue = integerPart + '.' + decimalPart;
			// 如果整数部分为空且存在小数点,则重置输入框(首位不能是小数点)
			if (integerPart === '' && decimalPart !== '') {
				newValue = '';
			}
		} else {
			// 没有小数点,只校验整数部分(只允许数字)
			if (/\D/.test(newValue)) {
				newValue = newValue.replace(/\D/g, ''); // 移除非数字字符 
			}
		}
	}
	newValue = newValue.replace(/^0+(?=[0-9])/, ''); //去除首位的多个0(如001→1,01→1)

	console.log(newValue)
	this.$nextTick(() => { // 更新数据
		this.submitMoney = newValue;
	})
},
相关推荐
GISer_Jing9 小时前
告别手搓架构图!Excalidraw+AI Skills 高效绘制手绘风技术图
前端·人工智能·react.js
jiayong239 小时前
第 7 课:第三轮真实重构,拆出新增任务弹窗
服务器·前端·重构
钛态9 小时前
前端WebSocket实时通信:别再用轮询了!
前端·vue·react·web
爱学习的程序媛9 小时前
浏览器内核揭秘:JavaScript 和 UI 的“主线程争夺战”
前端·性能优化·浏览器·web
你挚爱的强哥9 小时前
欺骗加载进度条,应用于无法监听接口数据传输进度的情况
前端·javascript·html
zhensherlock9 小时前
Protocol Launcher 系列:Mail Assistant 轻松发送 HTML 邮件
前端·javascript·typescript·node.js·html·github·js
恒本银河+9 小时前
基于MQTT+NFC标签项目开发教程
前端·javascript·nfc标签
GISer_Jing9 小时前
React 18+ 高级特性实战与面试精讲
javascript·react.js·面试
吴声子夜歌9 小时前
ES6——异步操作和async函数详解
前端·ecmascript·es6
小小小米粒10 小时前
生命周期 = Vue 实例从创建 → 挂载 → 更新 → 销毁的全过程钩子函数computed = 基于依赖缓存的计算属性
前端·javascript·vue.js