这里用到了正则表达式的 $1,$2 的方法.
() 就是起到一个分组作用,将匹配到的放到mathches集合中,$相当于集合名字,1-9就相当于索引,$1...$9相当于对应索引的值。注意下标是从1开始,表示第一个元素,不是从0开始。
如果将pat中所有的()都去掉,即: var pat=/\d{3}\d*\d{4}/ 会是什么结果呢?
结果是
没有括号之后,s1和s2匹配不到任何元素,所以就以字符串显示出来。
如果pat中保留第一个括号,即: var pat=/(\d{3})\d*\d{4}/ 结果如何?
结果是
这里$1匹配到了189,所以$1输出了189,而$2未匹配到任何内容,所以以字符串的形式输出。
javascript可以使用正则表达式来验证电话号码。
以下是使用正则表达式来验证电话号码是手机号码,座机号码和区分是否带区号:
function Phone(val)
{var isMobilePhone = /^([0-9]{3,4}-)?[0-9]{7,8}$/
var isFixMob= /^0?1[3|4|5|8][0-9]\d{8}$/
if(isFixMob.test(val)||isMobilePhone.test(val))
{return true}else{return false}}
if (Phone(myForm.Phone.value) == false)
{layer.alert('联系电话格式错误')myForm.Phone.focus()return false}
扩展资料:
正则表达式应用——实例应用
1.验证用户名和密码:("^[a-zA-Z]\w{5,15}$")正确格式:"[A-Z][a-z]_[0-9]"组成,并且第一个字必须为字母6~16位;
2.验证电话号码:("^(\d{3,4}-)\d{7,8}$")正确格式:xxx/xxxx-xxxxxxx/xxxxxxxx;
3.验证手机号码:"^1[3|4|5|7|8][0-9]{9}$";
4.验证身份证号(15位):"\d{14}[[0-9],0-9xX]",(18位):"\d{17}(\d|X|x)";
5.验证Email地址:("^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$");
6.只能输入由数字和26个英文字母组成的字符串:("^[A-Za-z0-9]+$");
7.整数或者小数:^[0-9]+([.][0-9]+){0,1}$
8.只能输入数字:"^[0-9]*$"。
9.只能输入n位的数字:"^\d{n}$"。
10.只能输入至少n位的数字:"^\d{n,}$"。
11.只能输入m~n位的数字:"^\d{m,n}$"。
12.只能输入零和非零开头的数字:"^(0|[1-9][0-9]*)$"。
13.只能输入有两位小数的正实数:"^[0-9]+(\.[0-9]{2})?$"。
14.只能输入有1~3位小数的正实数:"^[0-9]+(\.[0-9]{1,3})?$"。
15.只能输入非零的正整数:"^\+?[1-9][0-9]*$"。
参考资料:百度百科:正则表达