首页  >  文章  >  web前端  >  深入理解JS正则表达式之贪婪模式与非贪婪模式的解析

深入理解JS正则表达式之贪婪模式与非贪婪模式的解析

不言
不言原创
2018-07-11 09:45:372213浏览

这篇文章主要介绍了关于深入理解JS正则表达式之贪婪模式与非贪婪模式的解析,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

贪婪模式

之前说了正则的量词,但是量词会带来一个到底该匹配哪个的问题。

如下正则表达式:

\d{3,6}

这个正则表达式是匹配3到6个数字,但是当这个正则表达式被用来匹配12345678这个字符串,到底该匹配三个数字还是6个数字,亦或者是都不是?

可以先试试:

let text = '12345678'
let reg = /\d{3,6}/g
text.replace(reg, 'X')      // X78

可以看到该正则将123456六个数字替换为了X,也就是说,在正常模式下,正则表达式会尽可能多的匹配。

正常情况下,正则表达式采用贪婪模式,即,尽可能多的匹配。

非贪婪模式

但是,有时我们需要正则表达式尽可能少的匹配,也就是说,一旦成功匹配不再继续尝试,这就是非贪婪模式。那么,如何进入非贪婪模式呢?

做法很简单,在量词后加上?即可。

let text = '12345678'
let reg = /\d{3,6}?/g
text.replace(reg, 'X')      // X45678

可以发现,在非贪婪模式下,该正则只匹配了123,即最少匹配。

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

深入理解JS正则表达式之量词的解析

深入理解JS正则表达式之预定义类与边界的解析

以上是深入理解JS正则表达式之贪婪模式与非贪婪模式的解析的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn