Skip to content
← Back to rules

eslint/no-control-regex 正しさ

This rule is turned on by default.

何をするか

正規表現内の制御文字および一部のエスケープシーケンス(制御文字に一致するもの)を禁止します。

なぜ問題なのか

制御文字は、アスキーコード 0~31 の範囲にある特殊な非表示文字です。これらの文字は JavaScript の文字列でほとんど使用されません。したがって、これらに明示的に一致する要素を含む正規表現は、ほとんどの場合誤りである可能性が高いです。

このルールに違反するコードの例:

javascript
var pattern1 = /\x00/;
var pattern2 = /\x0C/;
var pattern3 = /\x1F/;
var pattern4 = /\u000C/;
var pattern5 = /\u{C}/u;
var pattern6 = new RegExp("\x0C"); // パターン内に直接の U+000C 文字
var pattern7 = new RegExp("\\x0C"); // \x0C パターン

このルールに準拠するコードの例:

javascript
var pattern1 = /\x20/;
var pattern2 = /\u0020/;
var pattern3 = /\u{20}/u;
var pattern4 = /\t/;
var pattern5 = /\n/;
var pattern6 = new RegExp("\x20");
var pattern7 = new RegExp("\\t");
var pattern8 = new RegExp("\\n");

使用方法

設定ファイルまたは CLI でこのルールを有効化するには、以下のようにします。

json
{
  "rules": {
    "no-control-regex": "error"
  }
}
bash
oxlint --deny no-control-regex

参考資料