no-dupe-class-members
不允許重複的類別成員
✅ 建議
在設定檔中使用 @eslint/js
的 recommended
設定會啟用此規則
如果類別成員中存在相同名稱的宣告,則最後一個宣告會靜默地覆寫其他宣告。這可能會導致非預期的行為。
class Foo {
bar() { console.log("hello"); }
bar() { console.log("goodbye"); }
}
const foo = new Foo();
foo.bar(); // goodbye
規則詳細資訊
此規則旨在標示在類別成員中使用重複名稱的情況。
範例
此規則的 錯誤 程式碼範例
在 Playground 中開啟
/*eslint no-dupe-class-members: "error"*/
class A {
bar() { }
}
class B {
bar() { }
}
class C {
bar;
}
class D {
bar;
}
class E {
static bar() { }
}
此規則的 正確 程式碼範例
在 Playground 中開啟
/*eslint no-dupe-class-members: "error"*/
class A {
bar() { }
qux() { }
}
class B {
get bar() { }
set bar(value) { }
}
class C {
bar;
qux;
}
class D {
bar;
qux() { }
}
class E {
static bar() { }
bar() { }
}
何時不該使用
此規則不應在 ES3/5 環境中使用。
在 ES2015 (ES6) 或更新版本中,如果您不希望收到關於類別成員中重複名稱的通知,您可以安全地停用此規則。
由 TypeScript 處理
當使用 TypeScript 時,停用此規則是安全的,因為 TypeScript 的編譯器會強制執行此檢查。
版本
此規則在 ESLint v1.2.0 中引入。