版本

no-class-assign

禁止重新分配类成员

推荐

配置文件中使用 @eslint/js 中的 recommended 配置启用此规则

ClassDeclaration 创建一个变量,我们可以修改该变量。

class A { }
A = 0;

但是,在大多数情况下,修改是一个错误。

规则详情

此规则旨在标记修改类声明的变量。

此规则的不正确代码示例

在 Playground 中打开
/*eslint no-class-assign: "error"*/

class A { }
A = 0;
在 Playground 中打开
/*eslint no-class-assign: "error"*/

A = 0;
class A { }
在 Playground 中打开
/*eslint no-class-assign: "error"*/

class A {
    b() {
        A = 0;
    }
}
在 Playground 中打开
/*eslint no-class-assign: "error"*/

let A = class A {
    b() {
        A = 0;
        // `let A` is shadowed by the class name.
    }
}

此规则的正确代码示例

在 Playground 中打开
/*eslint no-class-assign: "error"*/

let A = class A { }
A = 0; // A is a variable.
在 Playground 中打开
/*eslint no-class-assign: "error"*/

let A = class {
    b() {
        A = 0; // A is a variable.
    }
}
在 Playground 中打开
/*eslint no-class-assign: 2*/

class A {
    b(A) {
        A = 0; // A is a parameter.
    }
}

何时不使用

如果您不想收到关于修改类声明变量的通知,您可以安全地禁用此规则。

由 TypeScript 处理

当使用 TypeScript 时,禁用此规则是安全的,因为 TypeScript 的编译器会强制执行此检查。

版本

此规则在 ESLint v1.0.0-rc-1 中引入。

资源

更改语言