常见问题当前位置:鸿宇娱乐 > 常见问题 > >

鸿宇娱乐:JS正则表达式学习之贪婪和非贪婪模式

  

[JS,正则表达式,贪婪模式,非贪婪模式]JS正则表达式学习之贪婪和非贪婪模式实例总结

  

本文实例总结了JS正则表达式贪婪和非贪婪模式。分享给大家供大家参考,具体如下:  

  

首先上一段js代码:  

  
  
  try{  str="

abcdefg

abcdefghijkl

";  re1=str.match(/

[\W\w]+?<\/p>/ig);  alert("非贪婪模式:\r\n\r\n1:"+re1[0]+"\r\n2:"+re1[1]);  re1=str.match(/

[\W\w]+<\/p>/ig);  alert("贪婪模式:\r\n\r\n"+re1);  re1=str.match(/

(.+?)<\/p>/i);  alert("非贪婪模式,且不要标记:\r\n\r\n1:"+re1[1]);  re1=str.match(/

(.+)<\/p>/i);  alert("贪婪模式,且不要标记:\r\n\r\n"+re1[1]);  }catch(e){  alert(e.description)  }  

  
  

下边给出一些例子:  

  

贪婪模式:  

  

在使用修饰匹配次数的特殊符号时,有几种表示方法可以使同一个表达式能够匹配不同的次数,比如:"{m,n}", "{m,}", "?", "*", "+",具体匹配的次数随被匹配的字符串而定。这种重复匹配不定次数的表达式在匹配过程中,总是尽可能多的匹配。比如,针对文本 "dxxxdxxxd",举例如下:  

  

贪婪模式:  

  

  

                                  
表达式匹配结果
(d)(\w+)"\w+" 将匹配第一个 "d" 之后的所有字符 "xxxdxxxd"
(d)(\w+)(d)"\w+" 将匹配第一个 "d" 和最后一个 "d" 之间的所有字符 "xxxdxxx"。

  
  虽然 "\w+" 也能够匹配上最后一个 "d",但是为了使整个表达式匹配成功,  
  "\w+" 可以 "让出" 它本来能够匹配的最后一个 "d"

     

  

由此可见,鸿宇娱乐平台"\w+" 在匹配的时候,总是尽可能多的匹配符合它规则的字符。

  
  虽然第二个举例中,它没有匹配最后一个 "d",但那也是为了让整个表达式能够匹配成功。

  
  同理,带 "*" 和 "{m,n}" 的表达式都是尽可能地多匹配,带 "?" 的表达式在可匹配可不匹配的时候,  
  也是尽可能的 "要匹配"。这 种匹配原则就叫作 "贪婪" 模式 。

  

  

非贪婪模式:  

  

在修饰匹配次数的特殊符号后再加上一个 "?" 号,则可以使匹配次数不定的表达式尽可能少的匹配,使可匹配可不匹配的表达式,尽可能的 "不匹配"。这种匹配原则叫作 "非贪婪" 模式,也叫作 "勉强" 模式。如果少匹配就会导致整个表达式匹配失败的时候,与贪婪模式类似,非贪婪模式会最小限度的再匹配一些,以使整个表达式匹配成功。举例如下,针对文本 "dxxxdxxxd" 举例:  

  

  

                                  
表达式匹配结果
(d)(\w+?)"\w+?" 将尽可能少的匹配第一个 "d" 之后的字符,  
  结果是:"\w+?" 只匹配了一个 "x"
(d)(\w+?)(d)为了让整个表达式匹配成功,"\w+?" 不得不匹配 "xxx" 才可以让后边的 "d" 匹配,  
  从而使整个表达式匹配成功。因此,结果是:"\w+?" 匹配 "xxx"
  
  

  

更多的情况,举例如下:  

  

举例1:表达式 "(.*)" 与字符串 "

aa

bb

" 匹配时,匹配的结果是:成功;匹配到的内容是 "

aa

bb

" 整个字符串, 表达式中的 "" 将与字符串中最后一个 "" 匹配。

  

  

举例2:相比之下,表达式 "(.*?)" 匹配举例1中同样的字符串时,将只得到 "

aa

", 再次匹配下一个时,可以得到第二个 "

bb

"。

  

  

PS:这里再为大家提供2款非常方便的正则表达式工具供大家参考使用:  

  

JavaScript正则表达式在线测试工具:  
  
  

  

正则表达式在线生成工具:  
  
  

  

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript正则表达式技巧大全》、《JavaScript替换操作技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》、《JavaScript中json操作技巧总结》、《JavaScript错误与调试技巧总结》及《JavaScript数学运算用法总结》  

  

希望本文所述对大家JavaScript程序设计有所帮助。

  

(责任编辑:admin)

上一篇:js实现的四级左侧网站分类菜单实例

下一篇:详解JavaScript中Date.UTC()方法的使用

推荐内容

客户服务热线

010-400-12345

在线客服