MDN文檔git
1. 斷言
斷言,就是指明某個字符串前邊或者後邊,將會出現知足某種規律的字符串。github
零寬斷言:通常的正則表達式匹配,都是有 寬度 的,如:w+。 會將 '。' 一同匹配到。若是像 '。' 這樣的內容只是一種判斷條件,即不想被正則匹配到,就要使用到 零寬斷言了。正則表達式
(?=X)零寬度正先行斷言:僅當子表達式 X 在 此位置的右側匹配時才繼續匹配。例如,w+(?=d) 與後跟數字的單詞匹配,而不與該數字匹配。此構造不會回溯。
(?!X)零寬度負先行斷言:僅當子表達式 X 不在 此位置的右側匹配時才繼續匹配。例如,例如,w+(?!d) 與後不跟數字的單詞匹配,而不與該數字匹配 。
(?<=X)零寬度正後發斷言:僅當子表達式 X 在 此位置的左側匹配時才繼續匹配。例如,(?<=19)99 與跟在 19 後面的 99 的實例匹配。此構造不會回溯。
(?<!X)零寬度負後發斷言:僅當子表達式 X 不在此位置的左側匹配時才繼續匹配。例如,(?<!19)99 與不跟在 19 後面的 99 的實例匹配chrome
目前JS只支持先行斷言,後發斷言還不支持。不過目前chrome支持了後發斷言。segmentfault
2. 分組數組
分組的類型(四種):spa
捕獲型 - ()prototype
非捕獲型 - (?:)對象
正向前瞻型 - (?=)blog
反向前瞻型 - (?!)
其中只有捕獲型分組會暫存匹配到的串。
一個分組中能夠寫多個表達式:(表達式1|表達式2|表達式3), 表示匹配其中任意一個表達式。
分組能夠經過將某些表達式組合成總體,這樣能夠簡化表達式的書寫。例如將/testtesttest/寫爲/(test){3}/
3. 捕獲與引用
1) 嵌套分組的捕獲: 規則是以左括號出現的順序進行捕獲
<pre>
var reg = /((kid) is (a (doubi)))/
var str = "kid is a doubi"
reg.test( str ) // true
console.log(RegExp.$1) // kid is a doubi
console.log(RegExp.$2) // kid
console.log(RegExp.$3) // a doubi
console.log(RegExp.$4) // doubi
</pre>
經過 $1 能夠引用捕獲的字符串
2) replace中捕獲的使用:
3) 反向引用
正則表達式裏也能進行引用,這稱爲反向引用:
<pre>
var reg = /(w{3}) is 1/
reg.test('kid is kid') // true
reg.test('dik is dik') // true
reg.test('kid is dik') // false
reg.test('dik is kid') // false
</pre>
1引用了第一個被分組所捕獲的串,換言之,表達式是動態決定的。
注意,若是編號越界了,則會被當成普通的表達式:
<pre>
var reg = /(w{3}) is 6/;
reg.test( 'kid is kid' ); // false
reg.test( 'kid is 6' ); // true
</pre>
3. 字符集合
一般字符集合有由[]方括號括起來。
exec、test、match、replace
segmentfault文章
replace默認只替換第一個匹配到的字符串。
mdn文檔RegExp對象
RegExpObject.exec(string)
exec() 方法用於檢索字符串中的正則表達式的匹配,返回一個數組,其中存放匹配的結果。若是未找到匹配,則返回值爲 null;
狀況 1)RegExp爲非全局正則表達式;
狀況 2)RegExp爲全局正則表達式,exec()能夠像迭代器那樣,屢次調用,得到匹配值;
RegExpObject.test(string)
若是字符串 string 中含有與 RegExpObject 匹配的文本,則返回 true,不然返回 false