js正则限制 input 输入框匹配两位小数的数值,支持负数
在form表单的制作中,经常会遇到需要填入数量或金额这样的数值型字段,这时候就需要通过Js对input输入框的值做验证,如下方法为可支持负数的Js方法,希望可以帮助到需要的人。
// 文本框输入值处理,仅支持填入数值,支持负数
function CheckNum(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的金额
obj.value = parseFloat(obj.value);
}
if (obj.value.indexOf("-.") != -1 && obj.value != "") {//以上已经过滤,此处控制的是以-.开头,首位不能以-.开头
obj.value = parseFloat(obj.value);
}
}
方法调用:<input type="text" onchange="CheckNum(this);" />