ES6心得体会(五)之正则的扩展

五、正则的扩展
1.RegExp 构造函数
es5中,构造有两种情况
一、var regex = new RegExp('xyz','i');
=>  var regex = /xyz/i
二、var regex = new RegExp(/xyz/i);
=>  var regex = /xyz/i

es5不允许在第二种方法使用第二个参数

var regex = new RegExp(/xyz/,'i')  //报错

ES6 改变了这种行为。如果RegExp构造函数第一个参数是一个正则对象,那么可以使用第二个参数指定修饰符。而且,返回的正则表达式会忽略原有的正则表达式的修饰符,只使用新指定的修饰符。

new RegExp(/abc/ig, 'i').flags
// "i"
2. String.prototype.matchAll

增加了String.prototype.matchAll方法,可以一次性取出所有匹配。不过,它返回的是一个遍历器(Iterator),而不是数组。

const string = 'test1test2test3';

// g 修饰符加不加都可以
const regex = /t(e)(st(\d?))/g;

for (const match of string.matchAll(regex)) {
  console.log(match);
}
// ["test1", "e", "st1", "1", index: 0, input: "test1test2test3"]
// ["test2", "e", "st2", "2", index: 5, input: "test1test2test3"]
// ["test3", "e", "st3", "3", index: 10, input: "test1test2test3"]

遍历器转为数组是非常简单的,使用…运算符和Array.from方法就可以了。

// 转为数组方法一
[...string.matchAll(regex)]

// 转为数组方法二
Array.from(string.matchAll(regex));

你可能感兴趣的:(ES6心得体会(五)之正则的扩展)