捕獲組(capturing group)是正則表達(dá)式里比較常用,也是比較重要的概念,我個人覺得掌握這部分的知識是非常重要的。
這篇文章內(nèi)容不會很深入,但是盡量做到簡單易懂又全面。接下來的內(nèi)容主要是圍繞以下7個點:
1: () 捕獲組
2: (?:) non capturing group
3: (?=) positive lookahead
4: (?!) negative lookahead
5: (?<=) positive lookbehind
6: (?<!) negative lookbehind
7: (?=), (?!), (?<=), (?<!)的捕獲
1: () 捕獲組
/go+/
以上的正則表達(dá)式表示一個字母g后面跟上一個或者多個字母o,他能匹配go或者goooo。但是如果我們想+不只是運用到字母o上,而是運用到go這個整體上怎么辦呢?辦法就是給go加括號:
/(go)+/
為了全局匹配以及不考慮大小寫,我們接下來會給我們的正則加上ig,這兩個flag:
let reg = /(go)+/ig;'go is g gogo'.match(reg); //["go", "gogo"]
在上面的例子里面(go)就形成了一個捕獲組(capturing group)。接下來看一個使用捕獲組的例子來加深對它的理解:
let reg = /(/d{2}).(/d{2}).(/d{4})/;let originString = '10.25.2017';reg.test(originString); //trueRegExp.$1; //10RegExp.$2; //25RegExp.$2; //2017在上面這個例子里,我們有三組括號,形成了三個捕獲組,正則表達(dá)式(在javaScript里就是我們的RegExp)會緩存捕獲組所匹配的串,以$n表示,n就代表這第幾個捕獲組。
假如現(xiàn)在我們有一個需求:把顯示格式為 10.25.2017 的時間改為 2017-10-25 格式。
我們知道String的replace()方法經(jīng)常和正則表達(dá)式一起使用。在replace()方法里,我們可以直接使用捕獲組的結(jié)果:
let reg = /(/d{2}).(/d{2}).(/d{4})/;let originString = '10.25.2017';let newString = originString.replace(reg, '$3-$1-$2');console.log(newString);//"2017-10-25"2: (?:) non capturing group 非捕獲型分組
有的時候我們可能只想匹配分組,但是并不想緩存(不想捕獲)匹配到的結(jié)果,就可以在我們的分組模式前面加上?:。例如上面的時間的例子,我們不想捕獲第一個分組的結(jié)果,就可以這么做:
let reg = /(?:/d{2}).(/d{2}).(/d{4})/;let originString = '10.25.2017';reg.test(originString); //trueRegExp.$1; //25RegExp.$2; //2017originString.match(reg);// ["10.25.2017", "25", "2017", index: 0, input: "10.25.2017", groups: undefined]從上面的例子可以看出,我們的正則表達(dá)式依然是匹配的(test()的結(jié)果依然為true),但是RegExp.$1不是數(shù)字10,而是25,因為我們在第一個括號里加了?:,10就不會被捕獲。match()的執(zhí)行結(jié)果也會受?:的影響:match()的結(jié)果里不再有‘10'。
3: (?=) positive lookahead 正向前瞻型捕獲
有一個句子:1 apple costs 10 主站蜘蛛池模板: 蛟河市| 大英县| 北流市| 申扎县| 洪洞县| 富宁县| 老河口市| 淮安市| 黑山县| 曲松县| 辰溪县| 汤原县| 广南县| 阳谷县| 健康| 晋宁县| 壤塘县| 定结县| 菏泽市| 柳河县| 板桥市| 武功县| 永顺县| 历史| 五指山市| 蒙城县| 乡城县| 潞城市| 苗栗县| 东光县| 涡阳县| 宁德市| 德州市| 百色市| 宁阳县| 兴城市| 宜春市| 铁力市| 东丰县| 称多县| 天水市|