詳解javascript 正則表達(dá)式之分組與前瞻匹配
本文主要講解javascript 的正則表達(dá)式中的分組匹配與前瞻匹配的,需要對(duì)正則的有基本認(rèn)識(shí),本人一直對(duì)兩種匹配模棱不清。所以在這里總結(jié)一下,如有不對(duì),還望大神指點(diǎn)。
1.分組匹配:
1.1捕獲性分組匹配 ()
2.2非捕獲性分組匹配 (?:)
2前瞻匹配:
2.1正向前瞻匹配: (?=表達(dá)式) 后面一定要匹配有什么
2.2反向前瞻匹配: (?!表達(dá)式) 后面一定不能要有什么
1.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);//獲取到第一個(gè)分組 ([a-z]+) 匹配的結(jié)果 :word console.log(RegExp.$2);//獲取到第一個(gè)分組 (\d+) 匹配的結(jié)果 :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);//獲取到第一個(gè)分組 ([a-z]+) 匹配的結(jié)果 :a console.log(RegExp.$2);//獲取到第一個(gè)分組 (\d+) 匹配的結(jié)果 :123
分析:這個(gè)正則表達(dá)式匹配的是,至少一個(gè)字母,跟著一個(gè)空格,然后至少一個(gè)數(shù)字,
非全局就是第一次匹配正確就不會(huì)再往后匹配 了,
1.exec()方法提取的值是規(guī)定的,第一個(gè)值是正則表達(dá)式相匹配的文本,如上示例的"/([a-z]+)\s(\d+)/",第2個(gè)值是第一個(gè)字子表達(dá)式(即第一個(gè)分組),如上示例的"([a-z])",以此類推
2.即使是全局模式,exec()都不會(huì)全局匹配,循環(huán)調(diào)用exec()是唯一全局匹配的方式,所以你會(huì)發(fā)現(xiàn)上面使用exec()方法的結(jié)果是一樣
3.而 match 方法在全局模式的捕獲性分組匹配,會(huì)對(duì)正則表達(dá)式全局匹配,但是不會(huì)對(duì)子表達(dá)式匹配(分組),所以你會(huì)發(fā)現(xiàn)上面str1.match(regg1) 的結(jié)果是不會(huì)單獨(dú)以分組([a-z]+)字母或者分組(\d+)數(shù)字出現(xiàn),而是全局匹配整一個(gè)正則,所以結(jié)果是["word 123456","can 12","a 123"]
4.match 方法在非全局模式 的捕獲性分組匹配中,會(huì)對(duì)正則表達(dá)式全局匹配,也會(huì)對(duì)子表達(dá)式匹配(分組),所以你發(fā)現(xiàn),str1.match(reg1)匹配的結(jié)果有單獨(dú)分組的匹配,但是因?yàn)槭欠侨郑缘谝淮纹ヅ湔_就結(jié)束了,只有["wold 123456","word","123456"],“wold 123456” 是整個(gè)表達(dá)式匹配的結(jié)果,“word” 是第一個(gè)分組([a-z]+)匹配的結(jié)果,“123456” 是第二分組(\d+) 匹配的結(jié)果
5.$1,$2... 分別包含正則表達(dá)式中的相對(duì)應(yīng)反向引用,在全局與非全局模式,如果結(jié)果集有多個(gè),會(huì)以最后一次匹配的結(jié)果來(lái)算,如上面,全局模式,匹配一共有三個(gè)符合的,["word 123456","can 12","a 123"],那么就以最后一個(gè)"a 123"為所有分組得到的結(jié)果,第一個(gè)分組是([a-z]+) 匹配的是字母所以是a,第二個(gè)分組是數(shù)字(\d+),所以是123 ,以此類推,如果只出現(xiàn)一次,一次也是當(dāng)最后一次,自然也是一樣的分析,哈哈哈,有點(diǎn)多余。。。。
1.2 (?:) 非捕獲性分組匹配 ,不捕獲子表達(dá)式(分組)
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"]
分析,和上面的捕獲性分組匹配是一樣的解析,只是不再匹配子表達(dá)式(分組)
2.1正向前瞻匹配: (?=表達(dá)式) 后面一定要匹配有什么
注意:前瞻分組匹配(?=表達(dá)式) 會(huì)作為匹配內(nèi)容,不會(huì)作為匹配結(jié)果返回
//實(shí)例,提取以jpg類型的圖片名稱 var str2 = "ab.jpg,admin/12.gif,and.jpg"; var reg3 = /[^\\]\w+(?=\.jpg)/g; console.log(str2.match(reg3));//["ab", ",and"]
2.2反向前瞻匹配: (?!表達(dá)式) 后面一定不能要有什么
//示例:匹配 連續(xù)a字母三個(gè)以上,且后面不能有數(shù)字 var str3 = "aaa12345,aaaadmin,aaaaaadd,dlala"; var reg4 = /a{3,}(?!\d+)/g; console.log(str3.match(reg4));//["aaaa","aaaaaa"]
總結(jié)
以上所述是小編給大家介紹的javascript 正則表達(dá)式之分組與前瞻匹配,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
關(guān)于HTTP傳輸中g(shù)zip壓縮的秘密探索分析
Gzip是一種流行的文件壓縮算法,現(xiàn)在的應(yīng)用十分廣泛,尤其是在Linux平臺(tái)。下面這篇文章主要給大家介紹了關(guān)于HTTP傳輸中g(shù)zip壓縮的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-01-01javascript實(shí)現(xiàn)獲取中文漢字拼音首字母
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)獲取中文漢字拼音首字母,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05Javascript對(duì)象中關(guān)于setTimeout和setInterval的this介紹
Javascript對(duì)象中關(guān)于setTimeout和setInterval的this介紹,需要的朋友可以參考下2012-07-07JavaScript 面向?qū)ο蟪绦蛟O(shè)計(jì)詳解【類的創(chuàng)建、實(shí)例對(duì)象、構(gòu)造函數(shù)、原型等】
這篇文章主要介紹了JavaScript 面向?qū)ο蟪绦蛟O(shè)計(jì),結(jié)合具體實(shí)例形式詳細(xì)分析了JavaScript面向?qū)ο蟪绦蛟O(shè)計(jì)中類的創(chuàng)建、實(shí)例對(duì)象、構(gòu)造函數(shù)、原型等相關(guān)概念、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下2020-05-05javascript檢查某個(gè)元素在數(shù)組中的索引值
在js中提供數(shù)據(jù)查找了函數(shù)有很多,但我查找了很久都沒(méi)有能實(shí)現(xiàn)我要的方法,后來(lái)發(fā)現(xiàn)可以使用indexOf函數(shù)來(lái)實(shí)現(xiàn)查找與定位數(shù)組元素索引值的具體方法,各位朋友可參考2016-03-03《javascript設(shè)計(jì)模式》學(xué)習(xí)筆記一:Javascript面向?qū)ο蟪绦蛟O(shè)計(jì)對(duì)象成員的定義分析
這篇文章主要介紹了《javascript設(shè)計(jì)模式》學(xué)習(xí)筆記Javascript面向?qū)ο蟪绦蛟O(shè)計(jì)對(duì)象成員的定義,結(jié)合實(shí)例形式分析了《javascript設(shè)計(jì)模式》中JavaScript面向?qū)ο蟪绦蛟O(shè)計(jì)的原理、定義、用法及操作注意事項(xiàng),需要的朋友可以參考下2020-04-04Javascript 數(shù)組添加一個(gè) indexOf 方法的實(shí)現(xiàn)代碼
Javascript 的字符串有個(gè) indexOf 的方法,能夠返回字符在指定的字符串中的位置,非常有用,本文介紹了如何給 Javascript 數(shù)組也添加一個(gè)類似的方法。2009-09-09