prefer-regex-literals
禁止使用 RegExp
构造函数,而应使用正则表达式字面量
💡 hasSuggestions
此规则报告的一些问题可以通过编辑器建议手动修复。
有两种方法可以创建正则表达式
- 正则表达式字面量,例如
/abc/u
。 RegExp
构造函数,例如new RegExp("abc", "u")
或RegExp("abc", "u")
。
当您想要动态生成模式时,构造函数特别有用,因为它接受字符串参数。
当使用带字符串字面量的构造函数时,不要忘记字符串转义规则仍然适用。如果您想在模式中放置反斜杠,则需要在字符串字面量中对其进行转义。因此,以下等效
new RegExp("^\\d\\.$");
/^\d\.$/;
// matches "0.", "1.", "2." ... "9."
在上面的示例中,正则表达式字面量更容易阅读和理解。此外,在字符串字面量中省略额外的 \
是一种常见错误,这将产生完全不同的正则表达式。
new RegExp("^\d\.$");
// equivalent to /^d.$/, matches "d1", "d2", "da", "db" ...
当预先知道正则表达式时,建议避免在正则表达式表示法之上使用字符串字面量表示法,而应使用正则表达式字面量而不是构造函数。
规则详细信息
此规则禁止使用 RegExp
构造函数及其字符串字面量参数。
此规则还禁止使用不带表达式的模板字面量的 RegExp
构造函数以及不带表达式的 String.raw
标记模板字面量。
此规则不禁止所有 RegExp
构造函数的使用。它仍然应该用于动态生成的正则表达式。
此规则的错误代码示例
在代码游乐场中打开
/*eslint prefer-regex-literals: "error"*/
;
;
;
;
;
;
;
此规则的正确代码示例
在代码游乐场中打开
/*eslint prefer-regex-literals: "error"*/
/abc/;
/abc/u;
/\d\d\.\d\d\.\d\d\d\d/;
/^\d\.$/;
// RegExp constructor is allowed for dynamically generated regular expressions
new RegExp(pattern);
RegExp("abc", flags);
new RegExp(prefix + "abc");
RegExp(`${prefix}abc`);
new RegExp(String.raw`^\d\. ${suffix}`);
选项
此规则具有一个对象选项
- 将
disallowRedundantWrapping
设置为true
会额外检查不必要地包装的正则表达式字面量(默认值为false
)。
disallowRedundantWrapping
默认情况下,此规则不会检查何时不必要地将正则表达式字面量包装在 RegExp
构造函数调用中。当选项 disallowRedundantWrapping
设置为 true
时,此规则也将禁止此类不必要的模式。
{ "disallowRedundantWrapping": true }
的错误代码示例
在代码游乐场中打开
/*eslint prefer-regex-literals: ["error", {"disallowRedundantWrapping": true}]*/
;
;
{ "disallowRedundantWrapping": true }
的正确代码示例
在代码游乐场中打开
/*eslint prefer-regex-literals: ["error", {"disallowRedundantWrapping": true}]*/
/abc/;
/abc/u;
new RegExp(/abc/, flags);
版本
此规则在 ESLint v6.4.0 中引入。