ESLint v8.x reached end-of-life on 2024-10-05 and is no longer maintained. Upgrade or consider long-term support options
Versions

no-class-assign

Disallow reassigning class members

✅ Recommended

The "extends": "eslint:recommended" property in a configuration file enables this rule

ClassDeclaration creates a variable, and we can modify the variable.

/*eslint-env es6*/

class A { }
A = 0;

But the modification is a mistake in most cases.

Rule Details

This rule is aimed to flag modifying variables of class declarations.

Examples of incorrect code for this rule:

Open in Playground
/*eslint no-class-assign: "error"*/
/*eslint-env es6*/

class A { }
A = 0;
Open in Playground
/*eslint no-class-assign: "error"*/
/*eslint-env es6*/

A = 0;
class A { }
Open in Playground
/*eslint no-class-assign: "error"*/
/*eslint-env es6*/

class A {
    b() {
        A = 0;
    }
}
Open in Playground
/*eslint no-class-assign: "error"*/
/*eslint-env es6*/

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

Examples of correct code for this rule:

Open in Playground
/*eslint no-class-assign: "error"*/
/*eslint-env es6*/

let A = class A { }
A = 0; // A is a variable.
Open in Playground
/*eslint no-class-assign: "error"*/
/*eslint-env es6*/

let A = class {
    b() {
        A = 0; // A is a variable.
    }
}
Open in Playground
/*eslint no-class-assign: 2*/
/*eslint-env es6*/

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

When Not To Use It

If you don’t want to be notified about modifying variables of class declarations, you can safely disable this rule.

Version

This rule was introduced in ESLint v1.0.0-rc-1.

Resources

Change Language