prefer-regexp-exec
Enforce
RegExp#execoverString#matchif no global flag is provided.
🔧
Some problems reported by this rule are automatically fixable by the --fix ESLint command line option.
💭
This rule requires type information to run.
String#match is defined to work the same as RegExp#exec when the regular expression does not include the g flag.
Keeping to consistently using one of the two can help improve code readability.
This rule reports when a String#match call can be replaced with an equivalent RegExp#exec.
RegExp#execmay also be slightly faster thanString#match; this is the reason to choose it as the preferred usage.
.eslintrc.cjs
module.exports = {
"rules": {
"@typescript-eslint/prefer-regexp-exec": "error"
}
};
Examples
- ❌ Incorrect
- ✅ Correct
'something'.match(/thing/);
'some things are just things'.match(/thing/);
const text = 'something';
const search = /thing/;
text.match(search);
/thing/.exec('something');
'some things are just things'.match(/thing/g);
const text = 'something';
const search = /thing/;
search.exec(text);
Options
This rule is not configurable.
When Not To Use It
If you prefer consistent use of String#match for both with g flag and without it, you can turn this rule off.