JS match方法的返回数据的探究

本文深入讲解了JavaScript中match方法的使用,包括全局匹配与非全局匹配的区别,以及返回结果的详细解析,通过实例展示了如何利用该方法进行字符串的正则表达式匹配。

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

match方法是JS的字符串方法,详细说明可以看MDN的说明

如果正则表达式匹配成功的话,match方法会返回一个数组,而数组里的数据有两种形式,对应着匹配方式:全局匹配与非全局匹配。

1. 全局匹配

  全局匹配时,数组里的数据是匹配到的所有符合正则表达式的字符串。

2.非全局匹配

  非全局匹配时,数据里的数据则是第一个匹配的值以及正则表达式的子分组匹配到的值,再附加上三个属性:

  groups:一个捕获组数组或者 undefined(如果没有定义命名捕获组)。

  index:匹配结果的开始位置。

  input:进行匹配的原字符串。

例子:

var patt = /\(([a-z]*([\d]*)[a-z]*)\)/;
var pattg = /\(([a-z]*([\d]*)[a-z]*)\)/g;

var testStr = '(aaaaa11111(bbbbbb2222222bbaa)bbb(sss333sss)asdbas123bd)';

var result = testStr.match(patt);
var resultg = testStr.match(pattg);

console.log(result);  //=> ["(bbbbbb2222222bbaa)", "bbbbbb2222222bbaa", "2222222", index: 11, input: "(aaaaa11111(bbbbbb2222222bbaa)bbb(sss333sss)asdbas123bd)", groups: undefined]
console.log(resultg); //=> ["(bbbbbb2222222bbaa)", "(sss333sss)"]

  打印出来的两个结果在chrome浏览器控制台看是这样的:

  

  第一个结果是非全局匹配的,可以看到数组中原有三个数据,而这三个数据对应着正则表达式的三层分组:第一层是 \(([a-z]*([\d]*)[a-z]*)\) ,第二层是 ([a-z]*([\d]*)[a-z]*) ,第三层是 ([\d]*) 。(不清楚正则表达式分组的童鞋请自行了解,或查看参考链接。)

  第二个结果是全局匹配的,就是匹配正则表达式的所有结果。

 

参考链接:

1. MDN上的说明

2. w3school上的说明

3. 探究js正则匹配方法:match和exec

4. 正则表达式的分组

转载于:https://www.cnblogs.com/mengyouyouyou/p/11004117.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值