本文主要講解javascript 的正則表達式中的分組匹配與前瞻匹配的,須要對正則的有基本認識,本人一直對兩種匹配模棱不清。因此在這裏總結一下,若有不對,還望大神指點。javascript
1.分組匹配:
1.1捕獲性分組匹配 ()
2.2非捕獲性分組匹配 (?:)
2前瞻匹配:
2.1正向前瞻匹配: (?=表達式) 後面必定要匹配有什麼
2.2反向前瞻匹配: (?!表達式) 後面必定不能要有什麼java
1.一、捕獲性分組匹配 ()正則表達式
var str1 = "holle word 123456 can 12s a 123 a"; var reg1 =/([a-z]+)\s(\d+)/; //不是全局模式 ,以() 分組,這裏有兩組,每一組都將匹配獲得 var regg1 = /([a-z]+)\s(\d+)/g; //全局模式 g,以() 分組,這裏有兩組,每一組都將匹配獲得 //res :非全局模式 console.log(reg1.exec(str1)); //exec()方法:["wold 123456","word","123456"] console.log(str1.match(reg1));//match()方法:["word 123456","word","123456"] console.log(RegExp.$1);//獲取到第一個分組 ([a-z]+) 匹配的結果 :word console.log(RegExp.$2);//獲取到第一個分組 (\d+) 匹配的結果 :123456 //res :全局模式 console.log(regg1.exec(str1)); //exec()方法:["wold 123456","word","123456"] console.log(str1.match(regg1));//match()方法:["word 123456","can 12","a 123"] console.log(RegExp.$1);//獲取到第一個分組 ([a-z]+) 匹配的結果 :a console.log(RegExp.$2);//獲取到第一個分組 (\d+) 匹配的結果 :123
分析:這個正則表達式匹配的是,至少一個字母,跟着一個空格,而後至少一個數字,spa
非全局就是第一次匹配正確就不會再日後匹配 了,code
1.exec()方法提取的值是規定的,第一個值是正則表達式相匹配的文本,如上示例的"/([a-z]+)\s(\d+)/",第2個值是第一個字子表達式(即第一個分組),如上示例的"([a-z])",以此類推blog
2.即便是全局模式,exec()都不會全局匹配,循環調用exec()是惟一全局匹配的方式,因此你會發現上面使用exec()方法的結果是同樣圖片
3.而 match 方法在全局模式的捕獲性分組匹配,會對正則表達式全局匹配,可是不會對子表達式匹配(分組),因此你會發現上面str1.match(regg1) 的結果是不會單獨以分組([a-z]+)字母或者分組(\d+)數字出現,而是全局匹配整一個正則,因此結果是["word 123456","can 12","a 123"]ip
4.match 方法在非全局模式 的捕獲性分組匹配中,會對正則表達式全局匹配,也會對子表達式匹配(分組),因此你發現,str1.match(reg1)匹配的結果有單獨分組的匹配,可是由於是非全局,因此第一次匹配正確就結束了,只有["wold 123456","word","123456"],「wold 123456」 是整個表達式匹配的結果,「word」 是第一個分組([a-z]+)匹配的結果,「123456」 是第二分組(\d+) 匹配的結果console
5.$1,$2... 分別包含正則表達式中的相對應反向引用,在全局與非全局模式,若是結果集有多個,會以最後一次匹配的結果來算,如上面,全局模式,匹配一共有三個符合的,["word 123456","can 12","a 123"],那麼就以最後一個"a 123"爲全部分組獲得的結果,第一個分組是([a-z]+) 匹配的是字母因此是a,第二個分組是數字(\d+),因此是123 ,以此類推,若是隻出現一次,一次也是當最後一次,天然也是同樣的分析,哈哈哈,有點多餘。。。。class
1.2 (?:) 非捕獲性分組匹配 ,不捕獲子表達式(分組)
var str1 = "holle word 123456 can 12s a 123 a"; var reg2 = /(?:[a-z]+)\s(?:\d+)/; var regg2 = /(?:[a-z]+)\s(?:\d+)/g; //res :非全局模式 console.log(reg2.exec(str1));// exec(): 直接匹配["wold 123456"], console.log(str1.match(reg2));//match()方法:["word 123456"] //res :全局模式 console.log(regg2.exec(str1));// exec(): 直接匹配["wold 123456"], console.log(str1.match(regg2));//match()方法:["word 123456","can 12","a 123"]
分析,和上面的捕獲性分組匹配是同樣的解析,只是再也不匹配子表達式(分組)
2.1正向前瞻匹配: (?=表達式) 後面必定要匹配有什麼
注意:前瞻分組匹配(?=表達式) 會做爲匹配內容,不會做爲匹配結果返回
//實例,提取以jpg類型的圖片名稱 var str2 = "ab.jpg,admin/12.gif,and.jpg"; var reg3 = /[^\\]\w+(?=\.jpg)/g; console.log(str2.match(reg3));//["ab", ",and"]
2.2反向前瞻匹配: (?!表達式) 後面必定不能要有什麼
//示例:匹配 連續a字母三個以上,且後面不能有數字 var str3 = "aaa12345,aaaadmin,aaaaaadd,dlala"; var reg4 = /a{3,}(?!\d+)/g; console.log(str3.match(reg4));//["aaaa","aaaaaa"]
完結,謝謝。。。。