首頁 >web前端 >js教程 >js正規表示式最長匹配(貪婪匹配)和最短匹配(懶惰匹配)用法分析

js正規表示式最長匹配(貪婪匹配)和最短匹配(懶惰匹配)用法分析

高洛峰
高洛峰原創
2017-01-09 15:57:471712瀏覽

本文實例分析了js正規表示式最長匹配(貪婪匹配)和最短匹配(懶惰匹配)用法。分享給大家參考,具體如下:

最近在閱讀RequireJS 2.1.15源碼,源碼開始處定義了一系列的變量,有4個正則表達式:

var commentRegExp = /(\/\*([\s\S]*?)\*\/|([^:]|^)\/\/(.*)$)/mg,
cjsRequireRegExp = /[^.]\s*require\s*\(\s*["']([^'"\s]+)["']\s*\)/g,
jsSuffixRegExp = /\.js$/,
currDirRegExp = /^\.\//;

commentRegExp正則用來匹配JavaScript代碼中的註釋,/m的用法可以參考這篇文章:JS正規表示式修飾符中multiline(/m)用法分析,/g的用法參考這篇文章:JS正規表示式修飾符global(/g)用法分析。 commentRegExp中的*?這種用法之前沒有見過,覺得很奇怪,因為*在正則表達式中代表0個或任意多個,?代表0個或1個,剛開始覺得*?這種寫法很多餘。請教同事才知道,*?這種寫法是懶惰匹配。

alert(/abc([\w]*)/mg.exec("abc1abc2")[0]);//abc1abc2
alert(/abc([\w]*?)/mg.exec("abc1abc2")[0]);//abc

透過下面這段程式碼可以看出:最長匹配和最短匹配的差別透過這段程式碼可以看出:最長匹配和最短匹配的差別,一個匹配盡可能多的字符,一個匹配盡可能少的字元。一般正規表示式引擎預設都是最長匹配的,如果我們想要最短匹配,那麼可以在數量修飾符後面添加一個?變成最短匹配。

/***注释1****/ var name = "aty"; /***注释2****/
var name = "aty";

   

透過上面這段程式碼可以知道,為啥requirejs符合javascript註解要採用*?這個最短配對模式了吧。如果我們要刪除所有註釋,那麼應該採用最短匹配,否則var name="aty";這段程式碼會被替換掉。


更多js正規表示式最長匹配(貪婪匹配)和最短匹配(懶惰匹配)用法分析相關文章請關注PHP中文網!


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn