这里只说一个区别:java的字符串比js的字符串多一个转义符号“\”,工作中遇到的,用正则表达式验证手机号
js:
if(!(/^1[3-9]\d{9}$/.test(mobile))){
alert("请输入正确的手机号");
} else {
alert("true");
}
java:
// 手机号码格式
if (!mobile.matches("1([3-9])(\\d{9})")) { //多了一个转义字符,还有一些^$这样的字符串
result.setMessage(-1, "请输入正确的手机号码");
out.print(result);
return;
}
但是,如果js用显示方式定义正则表达式的话,两者的字符串没区别,如,验证只能输入6个数字:
js:
var reg = new RegExp("^\\d{6}$");
if(!reg.test(verificationCode)){
alert("请输入正确的验证码");
}else{
alert("true");
}
java:
if (!verificationCode.matches("^\\d{6}$")) {
result.setMessage(-1, "请输入正确的验证码");
out.print(result);
return;
}
以下内容转自其它网络:
javascript正则表达式和java正则表达式的区别
javascript中的正则表达式和java的正则表达式基本上是相同的,区别在于分组引用和对象,方法
具体区别:
1).javascript正则表达式创建有两种方法:
a.显式创建:
var re = new RegExp("正则表达式模式串");
re.test(要校验或处理的源字符串);
b.隐式创建:
var re = /正则表达式模式串/;
要校验或处理的源字符串.match(re);
2).分组捕获对象引用方式不同
javascript也是使用"()"进行分组,但是捕获对象用RegExp对象的$1到$99来引用捕获对象。
附录:常用的javascript正则表达式,java的也类似
ip地址校验正则表达式(IPv4):
/^(/d{1,2}|1/d/d|2[0-4]/d|25[0-5])(/.(/d{1,2}|1/d/d|2[0-4]/d|25[0-5])){3}$/
Email校验正则表达式:
/^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(/.[a-zA-Z0-9_-]+)+$/
格式为:2010-10-08类型的日期格式校验正则表达式:
/^/d{4}-(0?[1-9]|1[0-2])-(0?[1-9]|[1-2]/d|3[0-1])$/
格式为:23:11:34类型的时间格式校验正则表达式:
/^([0-1]/d|2[0-3]):[0-5]/d:[0-5]/d$/
转:
由于手机号段的不断更新,以前的正则表达式已经无法满足需求。重新编写这条表达式,号段资料来源依据:http://www.von-line.com/hao.htm
var regex = { mobile: /^0?(13[0-9]|15[012356789]|18[0236789]|14[57])[0-9]{8}$/ } |
“/”代表一个正则表达式。
“^”代表字符串的开始位置,“$”代表字符串的结束位置。
“?”代表匹配前面的字符一个或零个,所以这里0?的意思是手机号码可以以0开头或不以0开头。
接下的部分验证11位的手机号码,先从13开始,因为从130-139都有所以可选区间是[0-9],15开头的号码没有154所以[]里面没有4这个数字,当然也可以写成[0-35-9],下面18和14开的号码同上。
小括号括起来的代表一个子表达式,里面是4个可选分支分别用“|”来区分开来,在正则中“|”的优先级是最低的,这里每个分支匹配的都是3个字符(一个 []只能匹配一个字符,里面是可选的意思),也就是手机号码的前3位数字,那么后面还有8位数字需要匹配,可以是0-9的任意字符,所以是“[0-9] {8}”,{}中的数字代表匹配前面字符的个数。分析完毕。