在用户输入金钱相关的输入框时,需要限制小数点后两位
html:
<input type="number" onkeyup="num(this)" />
js:
function num(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'); //只能输入两个小数
}
input的正整数验证
html:
<input onkeyup='checkInt(this)' type="number" />
js:
function checkInt(e) {
var re = new RegExp("^[0-9]*[1-9][0-9]*$");
if (e.value != "") {
if (!re.test(e.value)) {
e.value = "";
e.focus();
}
}
}