likes
comments
collection
share

input纯数字框

作者站长头像
站长
· 阅读数 45

input纯数字框

只能输入整数:

<input type="text" name="text" onkeyup="this.value=this.value.replace(/\D/g,'')" onpaste="this.value=this.value.replace(/\D/g,'')" />

只能输入数字,包括小数点:

<input type="text" name="text" onkeyup="this.value=this.value.replace(/[^0-9.]/g,'')" />
注解:这里的正则用处是输入的值不是数字就替换为空。引用onkeyup 事件会在键盘按键被松开时发生,onpaste 是粘贴触发引用replace() 方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串引用\D:类似[ ^0-9 ] 非数字 g :全局匹配

控制input只能输入数字和两位小数

<input type="text" name="je" onkeyup="clearNum(this)" />
function clearNum(obj){
    obj.value = obj.value.replace(/[^\d.]/g,""); //清除"数字"和"."以外的字符
    obj.value = obj.value.replace(/^\./g,""); //验证第一个字符是数字
    obj.value = obj.value.replace(/\.{2,}/g,"."); //只保留第一个, 清除多余的
    obj.value = obj.value.replace(".","$#$").replace(/\./g,"").replace("$#$",".");
    obj.value = obj.value.replace(/^(\-)*(\d+)\.(\d\d).*$/,'$1$2.$3'); //只能输入两个小数
    if(obj.value.indexOf(".")< 0 && obj.value !=""){//以上已经过滤,此处控制的是如果没有小数点,首位不能为类似于 01、02的金额 
            if(obj.value.substr(0,1) == '0' && obj.value.length == 2){ 
                    obj.value= parseFloat(obj.value);     
            } 
     }
}
转载自:https://segmentfault.com/a/1190000042264508
评论
请登录