美文网首页让前端飞
关于js正则表达式的贪婪和懒惰模式

关于js正则表达式的贪婪和懒惰模式

作者: SimpleCXD | 来源:发表于2018-11-30 23:42 被阅读0次

1、量词

正则表达式的量词有:* + ? {}
* : 匹配0次到多次
+ : 匹配1次到多次
? : 匹配0次或1次
{n,m} : 匹配至少n次,最多m次
{n} : 匹配n次
{0,} : 等价于*
{1,} : 等价于+
{0,1} : 等价于?

量词默认是贪婪模式,当在量词后面加上一个问号?时,就变成了懒惰模式。

2、贪婪模式

使用量词(* + ? {})时,默认为贪婪模式。
贪婪模式尝试匹配最多字符,具体怎么做呢?
首先尝试匹配整个字符串,如果匹配不成功,就去掉最后一个字符,并再次尝试匹配,直到匹配成功或者字符串为空为止。
举个例子:

demo1.js
let str1 = 'xxx123xxxxxxxxxx123xxx';
let regex1 = /.*123/; 
console.log(regex1.exec(str1)[0]);

输出结果:'xxx123xxxxxxxxxx123'
分析demo1代码,由于使用量词,因此默认为贪婪模式,会尝试匹配最多字符,即匹配全部字符
第1次尝试:'xxx123xxxxxxxxxx123xxx' 与 /.
123/ 不匹配
第2次尝试:'xxx123xxxxxxxxxx123xx' 与 /.123/ 不匹配
第3次尝试:'xxx123xxxxxxxxxx123x' 与 /.
123/ 不匹配
第4次尝试:'xxx123xxxxxxxxxx123' 与 /.*123/ 匹配
因此匹配结果为:'xxx123xxxxxxxxxx123'

3、懒惰模式

在量词(* + ? {})后直接加上?时,即为懒惰模式。
懒惰模式尝试匹配最少字符,具体怎么做呢?
首先尝试匹配空字符串,如果匹配不成功,就多读取一个字符,并再次尝试匹配,直到匹配成功或者整个字符串读取完为止。
看下面例子:

demo2.js
let str2 = "xxx123xxxxxxxxxx123xxx";
let regex2 = /3*?/;
console.log(regex2.exec(str2)[0]);

输出结果:''

分析demo2代码,由于在量词后加入了?,因此采用懒惰模式,会尝试匹配最少字符。
第1次尝试:'' 与 /3
?/ 匹配
因此匹配结果为:''

相关文章

  • 正则表达式possessive、greediness和lazin

    正则表达式(Regular Expression)的贪婪模式(Greediness)和懒惰模式(Laziness)...

  • 关于js正则表达式的贪婪和懒惰模式

    1、量词 正则表达式的量词有:* + ? {}* : 匹配0次到多次+ : 匹配1次到多次? : 匹配0次或1次{...

  • 正则表达式的贪婪模式和非贪婪模式

    一、什么是贪婪模式和非贪婪模式? 定义 贪婪模式:正则表达式趋向于匹配最大长度。 非贪婪模式:正则表达式趋向于匹配...

  • day05

    A.你今天学到了什么 1.正则表达式的默认属性 2.正则表达式的test()方法 3.量词的贪婪模式和懒惰模式 4...

  • 正则表达式

    贪婪模式和非贪婪模式 正则表达式是贪婪匹配的。比如:'123456789'.replace(/\d{3,6}/g,...

  • 正则表达式 python 实现

    正则表达式 1.原子2.元字符3.模式修正4.贪婪模式5.懒惰模式 1.原子 原子是正则表达式中最基本的组成单位,...

  • 正则表达式

    基础正则表达式 拓展正则表达式 贪婪与懒惰

  • JS 正则表达式#2贪婪,懒惰模式

    贪婪,懒惰模式 重复匹配 在正则表达式语法中,定义了一组重复类量词,如表所示。它们定义了重复匹配字符的确数或约数。...

  • Day10 JS & ajax

    (续) 上一节正则表达式 贪婪模式 1. JS内置对象 Date 动态时钟Demo 2. AJAX 2.1 JS原...

  • 正则表达式基础到高阶(语法)

    正则表达式基础到高阶(语法) 元字符 反义 重复模式 贪婪与懒惰 分组 后向引用 要匹配 taobao taoba...

网友评论

    本文标题:关于js正则表达式的贪婪和懒惰模式

    本文链接:https://www.haomeiwen.com/subject/laakcqtx.html