关于html:input纯数字框

32次阅读

共计 943 个字符,预计需要花费 3 分钟才能阅读完成。

只能输出整数:

<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);     
            } 
     }
}

正文完
 0