JavaScript实现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 }      

 

posted @ 2018-03-27 17:10  一线大码  Views(619)  Comments(0Edit  收藏  举报