跳至主内容

@babel/plugin-transform-named-capturing-groups-regex

非官方测试版翻译

本页面由 PageTurner AI 翻译(测试版)。未经项目官方认可。 发现错误? 报告问题 →

信息

此插件已包含在 @babel/preset-envES2018 标准中。 注意:该插件生成的代码需要 ES6 正则表达式功能。 如需支持旧版浏览器,请使用 runtime: false 选项或导入适当的 polyfill(例如 core-js)。

此插件用于转换正则表达式字面量以支持命名捕获组。它不会修补 new RegExp 构造函数,因为其参数无法静态预转换:如需处理函数/类的运行时行为,您需要使用 polyfill 替代方案。

示例

输入

JavaScript
var re = /(?<year>\d{4})-(?<month>\d{2})-(?<day>\d{2})/;

console.log(re.exec("1999-02-29").groups.year);

输出

JavaScript
var re = _wrapRegExp(/(\d{4})-(\d{2})-(\d{2})/, { year: 1, month: 2, day: 3 });

console.log(re.exec("1999-02-29").groups.year);

安装

npm install --save-dev @babel/plugin-transform-named-capturing-groups-regex

用法

通过配置文件(推荐)

babel.config.json
{
"plugins": ["@babel/plugin-transform-named-capturing-groups-regex"]
}

通过命令行

Shell
babel --plugins @babel/plugin-transform-named-capturing-groups-regex script.js

通过 Node API

JavaScript
require("@babel/core").transformSync("code", {
plugins: ["@babel/plugin-transform-named-capturing-groups-regex"],
});

配置选项

runtime

boolean 类型,默认为 true

禁用此选项时,Babel 将不会使用 _wrapRegExp 辅助函数来包装正则表达式。 输出结果仅支持内部组引用,不支持运行时属性:

JavaScript
var stringRe = /(?<quote>"|').*?\k<quote>/;

stringRe.test("'foo'"); // "true", works
stringRe.exec("'foo'").groups.quote; // Error
提示

你可以在此处阅读更多关于配置插件选项的信息。