Eslint参考手册
规则 | Rules
no-this-before-super
"extends": "eslint:recommended"
配置文件中的属性启用此规则。
在派生类的构造函数中,如果在调用之前使用this
/ ,则会引发参考错误。supersuper()
此规则检查this
/ super
关键字在构造函数,然后报告那些之前super()
。
规则细节
这条规则的目的是在呼叫前标记this
/ super
关键字super()
。
例子
此规则的错误代码示例:
/*eslint no-this-before-super: "error"*/
/*eslint-env es6*/
class A extends B {
constructor() {
this.a = 0;
super();
}
}
class A extends B {
constructor() {
this.foo();
super();
}
}
class A extends B {
constructor() {
super.foo();
super();
}
}
class A extends B {
constructor() {
super(this.foo());
}
}
此规则的正确代码示例:
/*eslint no-this-before-super: "error"*/
/*eslint-env es6*/
class A {
constructor() {
this.a = 0; // OK, this class doesn't have an `extends` clause.
}
}
class A extends B {
constructor() {
super();
this.a = 0; // OK, this is after `super()`.
}
}
class A extends B {
foo() {
this.a = 0; // OK. this is not in a constructor.
}
}
何时不使用它
如果您不想在构造函数中使用this
/ super
之前收到通知super()
,可以安全地禁用此规则。
版本
该规则在 ESLint 0.24.0 中引入。
资源
- Rule source
- Documentation source
规则 | Rules相关

ESLint 是一个代码规范和错误检查工具,有以下几个特性。所有东西都是可以插拔的。你可以调用任意的 rule api 或者 formatter api 去打包或者定义 rule or formatter。任意的 rule 都是独立的。没有特定的 coding style,你可以自己配置。
主页 | https://eslint.org/ |
源码 | https://github.com/eslint/eslint |
发布版本 | 4.12.0 |