@babel/plugin-transform-named-capturing-groups-regex
非官方测试版翻译
本页面由 PageTurner AI 翻译(测试版)。未经项目官方认可。 发现错误? 报告问题 →
信息
此插件已包含在 @babel/preset-env 的 ES2018 标准中。
注意:该插件生成的代码需要 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
- Yarn
- pnpm
- Bun
npm install --save-dev @babel/plugin-transform-named-capturing-groups-regex
yarn add --dev @babel/plugin-transform-named-capturing-groups-regex
pnpm add --save-dev @babel/plugin-transform-named-capturing-groups-regex
bun add --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
提示
你可以在此处阅读更多关于配置插件选项的信息。