es6+正则扩展

捕获分组

  1. 普通捕获方式
    const str = '<h1 title="你好,世界">hello world</h1>';
    const reg = /^<h1 title="(.*)">(.*)<\/h1>$/;
    console.log(reg.exec(str));
    
    在这里插入图片描述
    返回结果说明
    ① 0:整体匹配的结果
    ② 1:第一个(.*)匹配的结果
    ③ 2:第二个(.*)匹配的结果
  2. 命名捕获分组
    【通过?<>方式,将正则捕获到的值添加到groups中,方便拿取】
    const str = '<h1 title="你好,世界">hello world</h1>';
    const reg = /^<h1 title="(?<title>.*)">(?<inner>.*)<\/h1>$/;
    console.log(reg.exec(str));
    
    在这里插入图片描述

反向断言

  1. 普通正向断言
    【通过?=,匹配数字,且后面必须是t的】

    const str = '123yyyy456ttttt';
    const reg = /\d+(?=t)/;
    console.log(reg.exec(str));
    

    在这里插入图片描述

  2. 反向断言
    【通过?<=,匹配数字,且前面必须是b的】

    const str = 'bbb123yyyy456ttttt';
    const reg = /(?<=b)\d+/;
    console.log(reg.exec(str));
    

    在这里插入图片描述

dotAll模式

  1.  . 默认匹配的是除换行符\n以外的任意字符

    const str = `
    	bbb123aay
    	y456ttttt
    `;
    const reg = /y.+y/;
    console.log(reg.exec(str)); // 匹配结果为null
    const reg1 = /y\s+y/;
    console.log(reg1.exec(str));
    

    在这里插入图片描述

  2. dotAll模式就是让 . 能够匹配所有字符,方式是添加模式修正符s(与i g同级)

    const str = `
    	bbb123aay
    	y456ttttt
    `;
    const reg = /y.+y/s;  // 写法更简便
    console.log(reg.exec(str));
    

    在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值