js正则表达式最长匹配(贪婪匹配)和最短匹配(懒惰匹
配)⽤法分析
本⽂实例分析了js正则表达式最长匹配(贪婪匹配)和最短匹配(懒惰匹配)⽤法。分享给⼤家供⼤家参考,具体如下:
最近在阅读RequireJS 2.1.15源码,源码开始处定义了⼀系列的变量,有4个正则表达式:
var commentRegExp = /(\/\*([\s\S]*?)\*\/|([^:]|^)\/\/(.*)$)/mg,
cjsRequireRegExp = /[^.]\s*require\s*\(\s*["']([^'"\s]+)["']\s*\)/g,
jsSuffixRegExp = /\.js$/,
currDirRegExp = /^\.\//;
alert(/abc([\w]*)/mg.exec("abc1abc2")[0]);//abc1abc2js 正则替换
alert(/abc([\w]*?)/mg.exec("abc1abc2")[0]);//abc
通过下⾯这段代码可以看出:最长匹配和最短匹配的差别通过这段代码可以看出:最长匹配和最短匹配的差别,⼀个匹配尽可能多的字符,⼀个匹配尽可能少的字符。⼀般正则表达式引擎默认都是最长匹配的,如果我们想要最短匹配,那么可以在数量修饰符后⾯添加⼀个?变成最短匹配。
/***注释1****/ var name = "aty"; /***注释2****/
var name = "aty";
通过上⾯这段代码可以知道,为啥requirejs匹配javascript注释要采⽤*?这种最短匹配模式了吧。如果我们要删除所有注释,那么应该采⽤最短匹配,否则var name="aty";这段代码会被替换掉。
PS:这⾥再为⼤家提供2款⾮常⽅便的正则表达式⼯具供⼤家参考使⽤:
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》、《》及《》
希望本⽂所述对⼤家JavaScript程序设计有所帮助。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论