整体来说,ES6对正则表达式的更新和改变不多也不难,下面简单总结于下
1.RegExp构造函数
ES5 RegExp构造函数只能接受字符串作为参数,而ES6中,其可以接受正则表达式作为参数
var reg = new RegExp(/xyz/i)
如果使用RegExp的构造函数的第二个参数指定修饰符,那么返回的正则表达式会忽略其原有的的修饰符
2.字符串的正则方法
字符串的四个可以使用正则表达式的方法:match(),replace(),search(),split(),ES6中在语言内部都调用了RegExp的实例方法,
从而做到所有与正则相关的方法都定义在RegExp对象上
3.u修饰符
ES6中的u修饰符专门用来正确处理大于 \uFFFF的Unicode字符,可以正确的处理4个字节的UTF-16编码
/^\uD83D/u.test('\uD83D\uDC2A') // false
/^\uD83D/.test('\uD83D\uDC2A') // true
上述代码中,test内的内容是一个4字节的UTF-16编码,代表一个字符。由于ES5不支持4字节的UTF-16编码,会将其识别为2个字符,导致第二行匹配成功,结果为true;
而第一行,加了u修饰符,ES6就会将其识别为一个字符,所以匹配不成功,结果为false。
3.1 点字符
点字符在正则表达式中表示除了换行符以外的任意单个字符,对于码点 大于0xFFFF的unicode字符,点字符不能识别,必须加上u修饰符
var s = "?"
/^.$/.test(s) //false
/^.$/u.test(s) //true
3.2 量词
使用u修饰符后,所有的量词都会正确的识别大于0xFFFF的Unicode字符
/?{2}/.test('??') //false
/?{2}/u.test('??') //true
3.3 预定义模式
u修饰符也影响到预定义模式能否正确识别码点 大于0xFFFF的unicode字符
/^\S$/.test('?') //false
/^\S$/u.test('?') //true
3.4 i修饰符
有些Unicode字符编码不同,但是字型很接近,比如 \u004B 和 \u212A 都是大写的K,不加u修饰符,就无法识别非规范的K字符
/[a-z]/i.test('\u212A') //false
/[a-z]/iu.test('\u212A') //true
4.y修饰符
ES6新增加了y修饰符,叫做黏连修饰符(sticky)。
y修饰符和g修饰符类似,也是全局匹配,后一次匹配都从第一次匹配成功的下一个位置开始。不同之处在于,g修饰符只要剩余位置中存在匹配就行,而y修饰符会确保匹配必须从剩余的第一个位置开始,
这就是黏连的意思
var s = "bbb_bb_b"
var p1 = /b+/g
var p2 = /b+/y
p1.exec(s) = ["bbb"]
p2.exec(s) = ["bbb"]
p1.exec(s) = ["bb"]
p2.exec(s) = null
5.sticky属性
与y修饰符相匹配,ES6的正则对象多了sticky属性,表示是否设置了y修饰符
var r = /hello\d/y
r.sticky = true
6.flags属性
ES6为正则表达式新增了flags属性,会返回正则表达式的修饰符
/dss/ig.flags //'gi'