金额输入的正则表达式

前端之家收集整理的这篇文章主要介绍了金额输入的正则表达式前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
 

document.close();
document.open();

var data = [',','3123,456.7','1,.2',1,2,3.5','789','123,456,789.01',7890.01','158.12','123.147',578.36','.5847',5247','12.58,478','0256'];
var re = /^([1-9][0-9]*(,[0-9]{3})*(\.[0-9]+)?)$/;
for (var i = 0; i < data.length; i++) {
document.write(data[i]);
document.write(" ");
if (re.test(data[i])) {
document.write("ÕýÈ·");
document.write("<br/>");
} else {
document.write("<span style=\"color:red\">´íÎó</span>");
document.write("<br/>");
}
}


,错误
3123,456.7正确
1,错误
1,.2错误
1,3.5错误
789正确
123,789.01正确
123,7890.01错误
158.12正确
123.147正确
1,578.36正确
.5847错误
,5247错误
12.58,478错误
0256错误

^([0-9]+|[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$ 具体分析:  ^[1-9][0-9]*$   这表示任意一个不以0开头的数字,但是,这也意味着一个字符"0"不通过,所以我们采用下面的形式:   ^(0|[1-9][0-9]*)$   一个0或者一个不以0开头的数字.我们还可以允许开头有一个负号:   ^(0|-?[1-9][0-9]*)$   这表示一个0或者一个可能为负的开头不为0的数字.OK,让我们不要这么严格了.让用户以0开头好了.把负号的匹配也去掉,因为钱总不能是负的吧.下面我们要加的是说明可能的小数部分:   ^[0-9]+(.[0-9]+)?$   必须说明的是,小数点后面至少应该有1位数,所以"10."是不通过的,但是"10"和"10.2"是通过的.   ^[0-9]+(.[0-9]{2})?$   这样我们规定小数点后面必须有两位,如果你认为太苛刻了,可以这样:   ^[0-9]+(.[0-9]{1,2})?$   这样就允许用户只写一位小数.下面我们该考虑数字中的逗号了,我们可以这样:   ^[0-9]{1,[0-9]{3})*(.[0-9]{1,2})?$   "1到3个数字,后面跟着任意个逗号+3个数字"很简单,不是吗?但是让我们使得逗号成为可选,而不是必须:   ^([0-9]+|[0-9]{1,2})?$   这就是最终结果

原文链接:https://www.f2er.com/regex/362261.html

猜你在找的正则表达式相关文章