js的exex()方法

exec() 方法用于检索字符串中的正则表达式的匹配。

1、exec() 方法返回一个数组,其中存放匹配的结果,如果未找到匹配,则返回值为 null。

let str = "aaa";
    let r1 = /a/g;
    let r2 = /b/g;
    console.log("r1匹配结果:", r1.exec(str));
    console.log("r2匹配结果:", r2.exec(str));

js的exex()方法

exec() 方法的功能非常强大,它是一个通用的方法,而且使用起来也比 test() 方法以及支持正则表达式的 String 对象的方法更为复杂。

除了数组元素和 length 属性之外,exec() 方法还返回两个属性。index 属性声明的是匹配文本的第一个字符的位置。input 属性则存放的是被检索的字符串 string。

我们可以看得出,在调用非全局(上面的例子是全局)的 RegExp 对象的 exec() 方法时,返回的数组与调用方法 String.match() 返回的数组是相同的。

 let str = "aaa";
    let r1 = /a/g;
    let r2 = /a/;
    console.log("r1匹配结果:", r1.exec(str));
    console.log("str-r1匹配结果:", str.match(r1));
    console.log("r2匹配结果:", r2.exec(str));
    console.log("str-r2匹配结果:", str.match(r2));

js的exex()方法

2、此数组的第 0 个元素是与正则表达式相匹配的文本,第 1 个元素是与 RegExpObject 的第 1 个子表达式相匹配的文本(如果有的话),第 2 个元素是与 RegExpObject 的第 2 个子表达式相匹配的文本(如果有的话),以此类推。

 let s = "5aabcaba_a4aba_a a_a_abca_a a a_acbbaa b aa";
    let r = /(((a)b)c)|(ba)/g;
    console.log(r.exec(s));

js的exex()方法

上面代码的正则共有4个子表达式,按顺序分别为:(((a)b)c)、((a)b)、(a)、(ba)

所以上面数组的第0个元素放的是:与正则表达式相匹配的文本,正则为(((a)b)c)|(ba),元素值为abc

第1个元素放的是第1个子表达式的(在第0个元素的基础上)匹配的值,即abc

第2个元素放的是第2个子表达式匹配的值,即ab

第3个元素放的是第3个子表达式匹配的值,即a

第4个元素放的是第4个子表达式匹配的值,由于第4个子表达式没有匹配到值,所以为undefined

3、但是,当 RegExpObject 是一个全局正则表达式时,exec() 的行为就稍微复杂一些。它会在 RegExpObject 的 lastIndex 属性指定的字符处开始检索字符串 string。当 exec() 找到了与表达式相匹配的文本时,在匹配后,它将把 RegExpObject 的 lastIndex 属性设置为匹配文本的最后一个字符的下一个位置。这就是说,您可以通过反复调用 exec() 方法来遍历字符串中的所有匹配文本。当 exec() 再也找不到匹配的文本时,它将返回 null,并把 lastIndex 属性重置为 0。

  let s = "5aabcaba_a4aba_a a_a_abca_a a a_acbbaa b aa";
    let r = /(((a)b)c)|(ba)/g;
    console.log(r.exec(s));
    console.log(r.exec(s));
    console.log(r.exec(s));
    console.log(r.exec(s));
    console.log(r.exec(s));
    console.log(r.exec(s));
    console.log(r.exec(s));
    console.log(r.exec(s));
    console.log(r.exec(s));

js的exex()方法

由上图可知,当第6个console.log(r.exec(s));没有匹配到,所以返回了null,lastIndex 也会重置为0,下一次调用时,又从头开始匹配了。

注意:如果在一个字符串中完成了一次模式匹配之后要开始检索新的字符串,就必须手动地把 lastIndex 属性重置为 0。

 let s = "5aabcaba_a4aba_a a_a_abca_a a a_acbbaa b aa";
    let r = /(((a)b)c)|(ba)/g;
    console.log(r.exec(s));
    console.log("把 lastIndex 属性重置为 0");
    r.lastIndex = 0;
    console.log(r.exec(s));
    console.log(r.exec(s));
    console.log(r.exec(s));
    console.log(r.exec(s));
    console.log(r.exec(s));
    console.log(r.exec(s));
    console.log(r.exec(s));
    console.log(r.exec(s));

js的exex()方法

提示:请注意,无论 RegExpObject 是否是全局模式,exec() 都会把完整的细节添加到它返回的数组中。这就是 exec() 与 String.match() 的不同之处,后者在全局模式下返回的信息要少得多。因此我们可以这么说,在循环中反复地调用 exec() 方法是唯一一种获得全局模式的完整模式匹配信息的方法。

 

js的exex()方法

上一篇:巧技拾遗 | JavaScript 中 Array.every 和 Array.map 的巧妙结合


下一篇:常用备考句型