码迷,mamicode.com
首页 > Web开发 > 详细

JS中input输入框的一些限制

时间:2018-03-27 18:52:52      阅读:281      评论:0      收藏:0      [点我收藏+]

标签:str   his   this   数字   key   div   indexof   解决   type   

限制只能输入正整数

<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输入框的一些限制

标签:str   his   this   数字   key   div   indexof   解决   type   

原文地址:https://www.cnblogs.com/wbyp/p/8658565.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!