只能输出整数:
<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); } }}