@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
- Yarn
- pnpm
- Bun
npm install --save-dev @babel/plugin-transform-duplicate-named-capturing-groups-regex
yarn add --dev @babel/plugin-transform-duplicate-named-capturing-groups-regex
pnpm add --save-dev @babel/plugin-transform-duplicate-named-capturing-groups-regex
bun add --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
提示
你可以在此处阅读更多关于配置插件选项的信息。