读懂javascript中的exec与match使用方法

126 阅读2分钟

javascript中与正则表达式有关的匹配字符串的函数主要有RegExp类的方法exec(string)以及String类的方法match(regex)

  1. exec是正则表达式的方法,而不是字符串的方法,它的参数才是字符串,如下所示:

    const re = new RegExp(/\d/);

    const str = "hello5world";

    或者使用perl风格:

    /\d/.exec( "hello5world" );

    match才是字符串类提供的方法,它的参数是正则表达式对象,如下用法是正确的:

    "hello5world".match(\d);

  2. exec和match返回的都是数组

    如果执行exec方法的正则表达式没有分组(没有括号括起来的内容),那么如果有匹配,他将返回一个只有一个元素的数组,这个数组唯一的元素就是该正则表达式匹配的第一个串;如果没有匹配则返回null。

    下面两个alert函数弹出的信息是一样的:

    const str= "good,look" ;

    const p=/oo/; //没有g属性

    alert(p.exec(str))

    alert(str.match(p))

    都是"oo"。在这种场合下exec等价于match。

    但是如果正则表达式是全局匹配(g属性)的,那么以上代码结果不一样了:

    const str= "good,look" ;

    const p=/oo/g; //没有g属性

    alert(p.exec(str))

    alert(str.match(p))

    分别是
    "oo"
    "oo,oo"。

    因为exec永远只返回第一个匹配,而match在正则指定了g属性的时候,会返回所有匹配。

  3. exec如果找到了匹配,而且包含分组的话,返回的数组将包含多个元素,第一个元素是找到的匹配,之后的元素依次为该匹配中的第一、第二...个分组

    如下的代码将弹出"cat2,at":

    const str = "goo2,look" ;

    const p=/g(oo)\d/;

    alert(p.exec(str))

    其中第一个元素是匹配的字符串"goo2",之后的元素是括号中匹配的"oo"。

  4. match函数在满足如下条件下,实现和exec一样的功能:

    1、正则表达式中含有分组(括号)
    2、返回唯一的匹配

    且看如下的代码:

    const str = "goo2,look" ;

    const p=/g(oo)\d/;

    alert(p.exec(str))

    alert(str.match(p))

    都将弹出消息"goo2,oo"

总结:

match是返回所有匹配的字符串合成的数组,但是正则表达式必须指定全局g属性才能返回所有匹配,不指定g属性则会返回一个只有一个元素的数组。

exec永远返回与第一个匹配相关的信息,其返回数组包括第一个匹配的字串,之后分别是第一个匹配的分组, 第二...个匹配的分组