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",举例如下:

贪婪模式:

由此可见,"\w+" 在匹配的时候,总是尽可能多的匹配符合它规则的字符。 虽然第二个举例中,它没有匹配最后一个 "d",但那也是为了让整个表达式能够匹配成功。 同理,带 "*" 和 "{m,n}" 的表达式都是尽可能地多匹配,带 "?" 的表达式在可匹配可不匹配的时候, 也是尽可能的 "要匹配"。这 种匹配原则就叫作 "贪婪" 模式 。

非贪婪模式:

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

表达式

更多的情况,举例如下:

举例1:表达式 "aa

bb

内容是 "aa

bb

举例2:相比之下,表达式 "aa

bb

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

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

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

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》、《》及《

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

原文链接:/js/43154.html

猜你在找的JavaScript相关文章

匹配结果