原文地址:http://www.cnblogs.com/snandy/p/3650309.htmljavascript
小括号在正则表达式这有如下意义html
1
2
3
|
var
reg1 = /(Matz)?/;
// 0或1个Matz
var
reg2 = /(Matz)+/;
// 1个以上Matz
var
reg3 = /(Matz)*/;
// 0或多个Matz
|
1
2
3
4
|
var
reg = /(Matz|Eich)/
reg.test(
'Matz'
)
// => true
reg.test(
'Eich'
)
// => true
reg.test(
'John'
)
// => false
|
1
2
3
4
5
6
|
var
reg = /(boy)\1/
// 至关于 /boyboy/
reg.test(
'boy'
)
// => false
reg.test(
'boyboy'
)
// => true
var
reg /(boy)(girl)\1\2/
reg.test(
'boygirlboygirl'
)
// => true
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
var
reg1 = /(\d{3}) (\d{3})/
var
str =
'111 222'
str.replace(reg1,
'$2 $1'
)
// => '222 111' , 注意这里的$2,$1,存放了匹配的字符串
var
reg2 = /(\d{3})(\d{4})(\d{4})/
var
mobile =
'13522722724'
reg2.test(mobile)
RegExp.$1
// => 135
RegExp.$2
// => 2272
RegExp.$3
// => 2724
var
reg3 = /(\d{3})(\d{4})(\d{4})/
var
mobile =
'13522722724'
mobile.replace(reg3,
'$1 $2 $3'
)
// => '135 2272 2724'
|
1
2
3
|
var
reg = /(?:\d+)/
reg.test(
'13522722724'
)
RegExp.$1
// => '' 不存储匹配的元素
|
较长的正则表达式中,反向引用会下降匹配速度,性能下降,不须要反向引用时应使用分组不捕获。java
它告诉正则表达式向前看一些字符但不移动位置,前瞻不匹配任何字符只匹配文本中的特定位置。正则表达式
1
2
3
4
5
|
var
reg = /(John) (?=Resig)/
reg.test(
'John'
)
// => false
reg.test(
'John Backus'
)
// => false
reg.test(
'John Reisg'
)
// => true
RegExp.$1
// => 'John',注意这里不是 "John Resig"
|
以下是一个利用前瞻实现手机号格式化的小函数函数
1
2
3
4
5
6
7
8
9
|
/*
* 手机号分隔
* 13522722724 -> 135 2272 2724
*/
function
separateMobile(num) {
var
arr = (
'0'
+ num ).replace(/(\d{4})(?=\d)/g,
"$1 "
).split(
''
)
arr.shift()
return
arr.join(
''
)
}
|