Javascript正则之懒惰性和贪婪性

本文详细介绍了正则表达式的使用方法,包括基本概念如懒惰性、贪婪性等,以及如何利用正则表达式进行字符串匹配和捕获,还对比了exec方法与match方法的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//exec->正则捕获

//每一次捕获的时候都是先进行默认的匹配,如果没有匹配成功,则结果为null;只有有匹配的内容才是一个数组

//捕获的内容格式

//1)捕获到的内容是一个数组

        数组中的第一项是当前大正则不活的内容

        index:捕获内容在字符串中开始的索引位置

        input:捕获的原始字符串

//2、正则捕获的特点

//!)懒惰性->每一次执行exec只捕获第一个匹配的内容,在不进行任何操作的话,在执行多次捕获,捕获的还是第一个匹配的内容

    //lastIndex:是正则每一次捕获在字符串中开始查找的位置,默认为0

var reg = /\d+/;

var str = "zjahdjas2015nsdfj2016";

console.log(reg.lastIndex)  //->0,说明我们第二次捕获的时候也是要从字符串索引为0处开始的

var res = reg.exec(str);

 

//2)如何解决懒惰性?在正则的末尾加一个修饰符"g"

    //修饰符:g、i、m

    global(g):全局匹配

    ignoreCase(i):忽略大小写匹配

    multiline(m):多行匹配

    //原理:加了全局修饰符g,正则每一次捕获结束后,我们的lastIndex的值都变为了最新的值,下一次捕获从最新的位置开始查找,这样就可以把所有需要捕获的地方都获取到

    利用正则捕获所有的内容

    var reg = /\d+/g;

    var str = "jiaoxue2015jiaoxue2016jiaoxue2017";

    var ary = [];

    var res = reg.exec(str);

    while(res) {

        ary.push(res[0]);

        res = reg.exec(str);

    }

    console.log(ary)

//3)贪婪性:正则的每一次捕获都是按照匹配最长的结果捕获的,例如:2符合,2015也符合正则,我们默认捕获的是2015

    //如何解决正则的贪婪性 ->在量词元字符后面添加一个?即可

    // ?在正则中有很多的作用:

    1、放在一个普通的元字符后面代表元字符最多只能出现一次

    2、放在一个量词的元字符后面是取消捕获时候的贪婪性

    3、

    

    var reg = /\d+?/g;

    var str = "jiaoxue2015jiaoxue2016jiaoxue2017";

    console.log(reg.exec(str)) //-> ["2"...]

//4、字符串中的match方法->把所有和正则匹配的字符都获取到

    

    var reg = /\d+?/g;

    var str = "jiaoxue2015jiaoxue2016jiaoxue2017";

    var ary = str.match(reg);

    console.log(ary)

    //虽然在当前的情况下match比我们的exec更加简单一些,但是match中存在一些自己处理不了的问题:在分组捕获的情况下,match只能捕获到大正则匹配的内容,而对于小正则匹配的内容是无法获取的。

转载于:https://my.oschina.net/u/3419199/blog/1457237

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值