es6基础(3)-正则扩展

时间:2023-11-22 14:23:02
 //正则扩展
{
let regex=new RegExp('xyz','i');
let regex2=new RegExp(/xyz/i); console.log(regex.test('xyz123'),regex2.test('xy'));
//后面的修饰符i覆盖原来的ig修饰符
let regex3=new RegExp(/xyz/ig,'i');
console.log(regex3.flags);
} {
let s='bbb_bb_b';
//g,y都是全局匹配
let a1=/b+/g;
let a2=/b+/y;
console.log('one:',a1.exec(s),a2.exec(s));//第一次都是从头开始匹配,bbb
console.log('two:',a1.exec(s),a2.exec(s));//第二次,g会忽略_直接bb,y不会忽略,所以匹配不到
//sticky查看是否开启了y修饰符
console.log(a1.sticky,a2.sticky);
} //ES6 对正则表达式添加了 u 修饰符,含义为 "Unicode模式",用来正确处理大于 \uFFFF 的Unicode字符。也就是说,会正确处理四个字符的 UTF-16 编码。
//字符串大于两个字节的要加上u
{
console.log('u-1',/^\uD83D/.test('\uD83D\uDC2A'));//true
console.log('u-2',/^\uD83D/u.test('\uD83D\uDC2A')); //false
//上面代码中,\uD83D\uDC2A 是一个四字节的UTF-16 编码,代表一个字符,但是,ES5不支持四个字节的 UTF-16 编码,会将其识别为两个字符,导致第一行代码结果为 true ,加了u修饰符以后,ES6就会识别其为一个字符,所以第二行代码结果为false。
//一旦加上 u 修饰符号,就会修改下面这些正则表达式的行为 console.log(/\u{61}/.test('a'));//false
console.log(/\u{61}/u.test('a'));//true
}
//点(.)字符在正则表达式中,含义是除了换行符以外的任意单个字符。对于码点大于 oxFFFF 的 Unicode 字符,点字符不能识别,必须加上 u 修饰符。
{
console.log(`\u{20BB7}`);
let s='