JS中input输入框的一些限制

Posted wbyp

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS中input输入框的一些限制相关的知识,希望对你有一定的参考价值。

限制只能输入正整数

<input type="text" onkeyup="if(this.value.length==1){this.value=this.value.replace(/[^1-9]/g,‘‘)}else{this.value=this.value.replace(/\D/g,‘‘)}"  
                   onafterpaste="if(this.value.length==1){this.value=this.value.replace(/[^1-9]/g,‘0‘)}else{this.value=this.value.replace(/\D/g,‘‘)}" />

限制只能输入最多两位小数的正数

<input type="text"  placeholder="优惠金额" onkeyup= "clearNoNum(this);"/>
 1 /*
 2  * 控制只能输入数字并且最多允许两位小数点
 3  */
 4 function clearNoNum(obj){  
 5     //修复第一个字符是小数点 的情况.  
 6     if(obj.value !=‘‘&& obj.value.substr(0,1) == ‘.‘){  
 7         obj.value="";  
 8     }  
 9     obj.value = obj.value.replace(/^0*(0\.|[1-9])/, ‘$1‘);//解决 粘贴不生效  
10     obj.value = obj.value.replace(/[^\d.]/g,"");  //清除“数字”和“.”以外的字符  
11     obj.value = obj.value.replace(/\.{2,}/g,"."); //只保留第一个. 清除多余的       
12     obj.value = obj.value.replace(".","$#$").replace(/\./g,"").replace("$#$",".");      
13     obj.value = obj.value.replace(/^(\-)*(\d+)\.(\d\d).*$/,‘$1$2.$3‘);//只能输入两个小数       
14     if(obj.value.indexOf(".")< 0 && obj.value !=""){//以上已经过滤,此处控制的是如果没有小数点,首位不能为类似于 01、02的金额  
15         if(obj.value.substr(0,1) == ‘0‘ && obj.value.length == 2){  
16             obj.value= obj.value.substr(1,obj.value.length);      
17         }  
18     }      
19 }      

 

以上是关于JS中input输入框的一些限制的主要内容,如果未能解决你的问题,请参考以下文章

Js如何实现 输入框的3秒内没输入就执行一个方法

jsp输入框如何对齐?每个输入框的文字长度不一样。。

js怎么控制文本框只能输入数字

js怎么控制文本框只能输入数字

JS怎么控制文本框输入的长度

js验证如何限制文本框只能输入数字