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