本文實(shí)例分析了js正則表達(dá)式最長(zhǎng)匹配(貪婪匹配)和最短匹配(懶惰匹配)用法。分享給大家供大家參考,具體如下:
最近在閱讀RequireJS 2.1.15源碼,源碼開(kāi)始處定義了一系列的變量,有4個(gè)正則表達(dá)式:
var commentRegExp = /(///*([/s/S]*?)/*//|([^:]|^)////(.*)$)/mg,cjsRequireRegExp = /[^.]/s*require/s*/(/s*["']([^'"/s]+)["']/s*/)/g,jsSuffixRegExp = //.js$/,currDirRegExp = /^/.///;
commentRegExp正則用來(lái)匹配JavaScript代碼中的注釋,/m的用法可以參考這篇文章://m.survivalescaperooms.com/article/101399.htm,/g的用法參考這篇文章://m.survivalescaperooms.com/article/101408.htm。commentRegExp中的*?這種用法之前沒(méi)有見(jiàn)過(guò),覺(jué)得很奇怪,因?yàn)?在正則表達(dá)式中代表0個(gè)或任意多個(gè),?代表0個(gè)或1個(gè),剛開(kāi)始覺(jué)得*?這種寫(xiě)法很多余。請(qǐng)教同事才知道,*?這種寫(xiě)法是懶惰匹配。
alert(/abc([/w]*)/mg.exec("abc1abc2")[0]);//abc1abc2alert(/abc([/w]*?)/mg.exec("abc1abc2")[0]);//abc通過(guò)下面這段代碼可以看出:最長(zhǎng)匹配和最短匹配的差別通過(guò)這段代碼可以看出:最長(zhǎng)匹配和最短匹配的差別,一個(gè)匹配盡可能多的字符,一個(gè)匹配盡可能少的字符。一般正則表達(dá)式引擎默認(rèn)都是最長(zhǎng)匹配的,如果我們想要最短匹配,那么可以在數(shù)量修飾符后面添加一個(gè)?變成最短匹配。
/***注釋1****/ var name = "aty"; /***注釋2****/var name = "aty";
通過(guò)上面這段代碼可以知道,為啥requirejs匹配javascript注釋要采用*?這種最短匹配模式了吧。如果我們要?jiǎng)h除所有注釋,那么應(yīng)該采用最短匹配,否則var name="aty";這段代碼會(huì)被替換掉。
PS:這里再為大家提供2款非常方便的正則表達(dá)式工具供大家參考使用:
JavaScript正則表達(dá)式在線測(cè)試工具:
http://tools.VeVB.COm/regex/javascript
正則表達(dá)式在線生成工具:
http://tools.VeVB.COm/regex/create_reg
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript正則表達(dá)式技巧大全》、《JavaScript替換操作技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript中json操作技巧總結(jié)》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注