版本

no-class-assign

禁止重新分配类成员

推荐

配置文件中使用来自 @eslint/jsrecommended 配置将启用此规则

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

class A { }
A = 0;

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

规则详情

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

此规则的错误代码示例

在代码游乐场中打开
/*eslint no-class-assign: "error"*/

class A { }
A = 0;
在代码游乐场中打开
/*eslint no-class-assign: "error"*/

A = 0;
class A { }
在代码游乐场中打开
/*eslint no-class-assign: "error"*/

class A {
    b() {
        A = 0;
    }
}
在代码游乐场中打开
/*eslint no-class-assign: "error"*/

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

此规则的正确代码示例

在代码游乐场中打开
/*eslint no-class-assign: "error"*/

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

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

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

何时不使用它

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

由 TypeScript 处理

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

版本

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

资源

更改语言