vue input框只能输入数字、小数点并限制长度

今天在写代码时遇到一些问题,inputtype属性值为number时,maxlength的设置会失效,type属性值为text时,又无法满足input只能输入数字的限制,找到的解决方法如下:

1、只能输入数字和小数点

@keyup="val.num = val.num.replace(/[^\d.]/g,'')"

具体内容:

<form v-for="(val,index) in list" :key='val.id'>
	<input 
	 type = "text"
	 placeholder = "请输入数量"
	 v-model = "val.num"
	 maxlength = "7"
	 @keyup = "val.num = val.num.replace(/[^\d.]/g,'')"
	/>
</form>

2、只能输入一个小数点,当第二位不是'.'时,首位不能为0

2.1 限制一个小数点

val.num= val.num
   .toString().//replace()方法是字符串方法
   .replace(/\.{2,}/g,'.')
   .replace('.','$#$')
   .replace(/\./g,'')
   .replace('$#$','.')//只能输入一个小数点

2.2 首位不能为0

if(val.num.length > 1 && val.num.substr(0,1) ==0 && val.num.substr(1,1) !='.'){
    val.num= val.num.substr(1,1)
}

2.3、首位不为点
方法一:

if(val.num.substr(0,1) == '.'){
    val.num=""
}

方法二:

if(val.num.indexOf(".") <= 0 && val.num!= ''){
   val.num= parseFloat(val.num)
}

2.4、限制小数点的位数(3位为例)

val.num= val.num
   .toString()
   .replace(/^()*(\d+)\.(\.?\d\d\d).*$/,'$2$2.$3')
                           //d有几个就是几位小数
  • 3
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值