這篇文章將為大家詳細講解有關(guān)正則表達式如何實現(xiàn)惰性匹配模式,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
創(chuàng)新互聯(lián)服務(wù)項目包括瑪納斯網(wǎng)站建設(shè)、瑪納斯網(wǎng)站制作、瑪納斯網(wǎng)頁制作以及瑪納斯網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,瑪納斯網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到瑪納斯省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!一.惰性模式的概念:
此模式和貪婪模式恰好相反,它盡可能少的匹配字符以滿足正則表達式即可,例如:
var str="axxyyzbdkb"; console.log(str.match(/a.*b/));
以上代碼是貪婪模式,于是能夠匹配整個字符串,下面將其修改成惰性匹配模式:
var str="axxyyzbdkb"; console.log(str.match(/a.*?b/));
上面的代碼即是惰性匹配,方法就是在重復(fù)量詞后面加一個問號(?)即可。
惰性匹配模式是盡可能少的匹配字符,但是必須要滿足正則表達式的匹配規(guī)則,例如上面的代碼,*可以重復(fù)匹配0個或者多個前面的字符或者子表達式,但是正則表達式的結(jié)尾必須是b,所以正則表達式可以匹配上面字符串中的axxyyzb。
總結(jié)如下:
1.在重復(fù)量詞后面添加問號(?)即可形成惰性匹配。
2.惰性匹配會盡可能少的匹配字符,但是必須要滿足整個匹配模式。
二.惰性限定符列表:
語法結(jié)構(gòu) | 語義解釋 |
*? | 可以重復(fù)任意次,但是盡可能重復(fù)少的次數(shù)。 |
+? | 可以重復(fù)1次或者任意多次,但是盡可能重復(fù)少的次數(shù),不過最少次數(shù)是1。 |
?? | 可以重復(fù)0次或1次,但盡可能少重復(fù)。 |
{n,m}? | 可以重復(fù)n到m此,但盡可能少重復(fù),最少匹配次數(shù)是n。 |
{n,}? | 可以重復(fù)n次以上,但盡可能少重復(fù),最少匹配n此。 |
簡介
其實貪婪和惰性很容易理解,從字面意思我們就可以知道,所謂的"貪婪"的意思就是,如果符合要求就一直往后匹配,一直到無法匹配為止,這就是貪婪模式。所謂的惰性模式就是一旦匹配到合適的就結(jié)束,不在繼續(xù)匹配下去了,下面我介紹幾個例子來主要講述一下。
首先講述一下貪婪模式的標示符:+,?,*,{n},{n,},{n,m}.惰性模式:+?,??,*??,{n}?,{n,}?,{n,m}?;
例子一
var pattern=/8[a-zA-Z0-9]*7/;貪婪模式 var string="abc8defghij7klngon8qrstwxy7";
這時使用了貪婪模式*,表示8與8之間可有有任意多個字母,那這個正則先匹配第一個8,如果匹配到了后,就無限制的匹配后面的內(nèi)容,只要后面的內(nèi)容都滿足[a-zA-Z0-9]就可以。一直匹配,匹配到不能再匹配為止,看緊接著后面的一個是不是7,如果不是那他就往前進一個(吐出一個看是不是7),如果不是再繼續(xù)吐直到吐出7為止,然后匹配到的就是這之間的內(nèi)容。所以結(jié)果匹配到的內(nèi)容就是整條字符串。
var pattern=/8[a-zA-Z0-9]*?7/ig;惰性模式 var string="abc8defghij7klngon8qrstwxy7";
上面正則使用了惰性模式*?,此時匹配方式是這樣的,先匹配一個8,然后在往后匹配一個字符看是不是符合[a-zA-Z0-9],如果符合,再去看緊接著后面的一個字符是不是7,如果是7就結(jié)束,如果不是就再往后匹配一個字符,看是不是符合[a-zA-Z0-9],如果符合,就再看緊接著后面的一個字符是不是7,如果是7就結(jié)束,否則,按照上面的方式依次循環(huán)下去,指導(dǎo)符合為止。
(2).貪婪和惰性模式還可以用另一種方式來表達。
例子二
var test=""; var pattern=/]*\/>/ig;
這樣也可以實現(xiàn)惰性模式,[^>]這個表示的就是在之間不能出現(xiàn)>,所以結(jié)果可以找尋每個標簽。
關(guān)于“正則表達式如何實現(xiàn)惰性匹配模式”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。