您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)正則表達(dá)式如何實(shí)現(xiàn)惰性匹配模式,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
一.惰性模式的概念:
此模式和貪婪模式恰好相反,它盡可能少的匹配字符以滿足正則表達(dá)式即可,例如:
var str="axxyyzbdkb"; console.log(str.match(/a.*b/));
以上代碼是貪婪模式,于是能夠匹配整個(gè)字符串,下面將其修改成惰性匹配模式:
var str="axxyyzbdkb"; console.log(str.match(/a.*?b/));
上面的代碼即是惰性匹配,方法就是在重復(fù)量詞后面加一個(gè)問(wèn)號(hào)(?)即可。
惰性匹配模式是盡可能少的匹配字符,但是必須要滿足正則表達(dá)式的匹配規(guī)則,例如上面的代碼,*可以重復(fù)匹配0個(gè)或者多個(gè)前面的字符或者子表達(dá)式,但是正則表達(dá)式的結(jié)尾必須是b,所以正則表達(dá)式可以匹配上面字符串中的axxyyzb。
總結(jié)如下:
1.在重復(fù)量詞后面添加問(wèn)號(hào)(?)即可形成惰性匹配。
2.惰性匹配會(huì)盡可能少的匹配字符,但是必須要滿足整個(gè)匹配模式。
二.惰性限定符列表:
語(yǔ)法結(jié)構(gòu) | 語(yǔ)義解釋 |
*? | 可以重復(fù)任意次,但是盡可能重復(fù)少的次數(shù)。 |
+? | 可以重復(fù)1次或者任意多次,但是盡可能重復(fù)少的次數(shù),不過(guò)最少次數(shù)是1。 |
?? | 可以重復(fù)0次或1次,但盡可能少重復(fù)。 |
{n,m}? | 可以重復(fù)n到m此,但盡可能少重復(fù),最少匹配次數(shù)是n。 |
{n,}? | 可以重復(fù)n次以上,但盡可能少重復(fù),最少匹配n此。 |
簡(jiǎn)介
其實(shí)貪婪和惰性很容易理解,從字面意思我們就可以知道,所謂的"貪婪"的意思就是,如果符合要求就一直往后匹配,一直到無(wú)法匹配為止,這就是貪婪模式。所謂的惰性模式就是一旦匹配到合適的就結(jié)束,不在繼續(xù)匹配下去了,下面我介紹幾個(gè)例子來(lái)主要講述一下。
首先講述一下貪婪模式的標(biāo)示符:+,?,*,{n},{n,},{n,m}.惰性模式:+?,??,*??,{n}?,{n,}?,{n,m}?;
例子一
var pattern=/8[a-zA-Z0-9]*7/;貪婪模式 var string="abc8defghij7klngon8qrstwxy7";
這時(shí)使用了貪婪模式*,表示8與8之間可有有任意多個(gè)字母,那這個(gè)正則先匹配第一個(gè)8,如果匹配到了后,就無(wú)限制的匹配后面的內(nèi)容,只要后面的內(nèi)容都滿足[a-zA-Z0-9]就可以。一直匹配,匹配到不能再匹配為止,看緊接著后面的一個(gè)是不是7,如果不是那他就往前進(jìn)一個(gè)(吐出一個(gè)看是不是7),如果不是再繼續(xù)吐直到吐出7為止,然后匹配到的就是這之間的內(nèi)容。所以結(jié)果匹配到的內(nèi)容就是整條字符串。
var pattern=/8[a-zA-Z0-9]*?7/ig;惰性模式 var string="abc8defghij7klngon8qrstwxy7";
上面正則使用了惰性模式*?,此時(shí)匹配方式是這樣的,先匹配一個(gè)8,然后在往后匹配一個(gè)字符看是不是符合[a-zA-Z0-9],如果符合,再去看緊接著后面的一個(gè)字符是不是7,如果是7就結(jié)束,如果不是就再往后匹配一個(gè)字符,看是不是符合[a-zA-Z0-9],如果符合,就再看緊接著后面的一個(gè)字符是不是7,如果是7就結(jié)束,否則,按照上面的方式依次循環(huán)下去,指導(dǎo)符合為止。
(2).貪婪和惰性模式還可以用另一種方式來(lái)表達(dá)。
例子二
var test="<img src="aaa/111.jpg"/><img src="aaa/112.jpg"/><img src="aaa/113.jpg"/>"; var pattern=/<img [^>]*\/>/ig;
這樣也可以實(shí)現(xiàn)惰性模式,[^>]這個(gè)表示的就是在<img到/>之間不能出現(xiàn)>,所以結(jié)果可以找尋每個(gè)<img>標(biāo)簽。
關(guān)于“正則表達(dá)式如何實(shí)現(xiàn)惰性匹配模式”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。