constructor-super
在构造函数中要求 `super()` 调用
✅ 推荐
在 配置文件 中使用来自 @eslint/js
的 `recommended` 配置将启用此规则。
派生类的构造函数必须调用 `super()`。非派生类的构造函数不得调用 `super()`。如果不遵守此规定,JavaScript 引擎将引发运行时错误。
此规则检查是否存在有效的 `super()` 调用。
规则详情
此规则旨在标记无效/缺少的 `super()` 调用。
这是一个语法错误,因为类中没有 `extends` 子句。
class A {
constructor() {
super();
}
}
此规则的不正确代码示例
在游乐场中打开
/*eslint constructor-super: "error"*/
class A extends B {
// Would throw a ReferenceError.
}
// Classes which inherits from a non constructor are always problems.
class C extends null {
constructor() {
; // Would throw a TypeError.
}
}
class D extends null {
// Would throw a ReferenceError.
}
此规则的正确代码示例
在游乐场中打开
/*eslint constructor-super: "error"*/
class A {
constructor() { }
}
class B extends C {
constructor() {
super();
}
}
何时不使用它
如果您不想在构造函数中收到有关无效/缺少 `super()` 调用的通知,您可以安全地禁用此规则。
由 TypeScript 处理
在使用 TypeScript 时禁用此规则是安全的,因为 TypeScript 的编译器强制执行此检查。
版本
此规则是在 ESLint v0.24.0 中引入的。