第5章 正则的扩展
5.1 RegExp构造函数
在 ES5 中,RegExp 构造函数的参数有两种情况。
第一种情况是,参数是字符串,这时第二个参数表示正则表达式的修饰符(flag)。
var hzh1 = new RegExp('xyz', 'i'); console.log("输出hzh1:"); console.log(hzh1); // 等价于 console.log(""); var hzh2 = /xyz/i; console.log("输出hzh2:"); console.log(hzh2);
[Running] node "e:\HMV\Babel\hzh.js" 输出hzh1: /xyz/i 输出hzh2: /xyz/i [Done] exited with code=0 in 0.289 seconds
第二种情况是,参数是一个正则表示式,这时会返回一个原有正则表达式的拷贝。
var hzh1 = new RegExp(/xzy/i); console.log("输出变量hzh1:"); console.log(hzh1); console.log(""); // 等价于 var hzh2 = /xzy/i; console.log("输出变量hzh2:"); console.log(hzh2);
[Running] node "e:\HMV\Babel\hzh.js" 输出变量hzh1: /xzy/i 输出变量hzh2: /xzy/i [Done] exited with code=0 in 0.197 seconds
但是,ES5 不允许此时使用第二个参数添加修饰符,否则会报错。
var hzh = new RegExp(/xyz/, 'i'); // Uncaught TypeError: Cannot supply flags // when constructing one RegExp from another
ES6 改变了这种行为。如果 RegExp 构造函数第一个参数是一个正则对象,那么可以使用第二个参数指定修饰符。而且,返回的正则表达式会忽略原有正则表达式的修饰符,只使用新指定的修饰符。
var hzh = new RegExp(/hzh/ig, 'i').flags; console.log("输出变量hzh:"); console.log(hzh);
[Running] node "e:\HMV\Babel\hzh.js" 输出变量hzh: i [Done] exited with code=0 in 0.21 seconds
上面的代码中,原有正则对象的修饰符是 ig,它会被第二个参数 i 覆盖。
5.2 字符串的正则方法
字符串对象共有 4 个方法可以使用正则表达式:match()、replace()、search()和 split()。
ES6 使这 4 个方法在语言内部全部调用 RegExp 的实例方法,从而做到所有与正则相关的方法都定义在 RegExp 对象上。
- String.prototype.match 调用 RegExp.prototype[Symbol.match]
- String.prototype.replace 调用 RegExp.prototype[Symbol.replace]
- String.prototype.search 调用 RegExp.prototype[Symbol.search]
- String.prototype.split 调用 RegExp.prototype[Symbol.split]
5.3 u修饰符
ES6 对正则表达式添加了 u 修饰符,含义为 “Unicode模式”,用来正确处理大于 \uFFFF 的 Unicode 字符。也就是说,可以正确处理4个字节的 UTF-16 编码。
var hzh1 = /^\uD83D/u.test('\uD83D\uDC2A'); console.log('输出变量hzh1'); console.log(hzh1); console.log(''); var hzh2 = /^uD83D/.test('\uD83D\uDC2A'); console.log('输出变量hzh2:'); console.log(hzh2);
[Running] node "e:\HMV\Babel\hzh.js" 输出变量hzh1 false 输出变量hzh2: false [Done] exited with code=0 in 0.179 seconds
上面的代码中,\uD83D\uDC2A 是一个 4 字节的 UTF-16 编码,代表一个字符。但是,ES5 不支持 4 字节的 UTF-16 编码,会将其识别为 2 个字符,导致第二行代码结果为 true 。加了 u 修饰符以后,ES6 就会识别其为一个字符,所以第一行代码结果为 false 。
一旦加上 u 修饰符,就会修改下面这些正则表达式的行为。
点字符
点(.)字符在正则表达式中的含义是除换行符以外的任意单个字符。对于码点大于 0xFFFF 的 Unicode 字符,点字符不能识别,必须加上u修饰符。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?