跳至主内容

@babel/plugin-transform-duplicate-named-capturing-groups-regex(转换重复命名捕获组的正则插件)

非官方测试版翻译

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

信息

此插件已包含在 @babel/preset-env 中,属于 ES2025 标准。

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

示例

输入

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

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

输出

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

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

安装

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

用法

通过配置文件(推荐)

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

通过命令行

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

通过 Node API

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

配置选项

runtime

boolean 类型,默认为 true

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

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

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

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

参考