Skip to content
← Back to rules

eslint/no-extend-native 懸念

何をするか

ObjectStringArray などのネイティブなグローバルオブジェクトに新しいプロパティを追加することを禁止します。

なぜ問題か

ネイティブオブジェクトを拡張すると、予期しない振る舞いや他のコードとの衝突を引き起こす可能性があります。

たとえば:

js
// 新しいプロパティを追加しているが、一見問題ないように見える
Object.prototype.extra = 55;

// ユーザーのオブジェクトを定義
const users = {
  1: "user1",
  2: "user2",
};

for (const id in users) {
  // "extra" と "1"、"2" のすべてが出力される:
  console.log(id);
}

このルールに対して誤りなコードの例:

js
Object.prototype.p = 0;
Object.defineProperty(Array.prototype, "p", { value: 0 });

このルールに対して正しいコードの例:

js
x.prototype.p = 0;
Object.defineProperty(x.prototype, "p", { value: 0 });

設定

このルールは以下のプロパティを持つ設定オブジェクトを受け入れます。

例外

type: string[]

default: []

このルールの例外として許可されるオブジェクトのリスト。

使用方法

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

json
{
  "rules": {
    "no-extend-native": "error"
  }
}
bash
oxlint --deny no-extend-native

参照