版本

no-self-assign

禁止赋值双方完全相同的情况

推荐

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

自身赋值没有效果,因此可能这些是由于不完整的重构而导致的错误。这些表明您仍然需要做的事情。

foo = foo;
[bar, baz] = [bar, qiz];

规则详情

此规则旨在消除自身赋值。

此规则的错误代码示例

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

foo = foo;

[a, b] = [a, b];

[a, ...b] = [x, ...b];

({a, b} = {a, x});

foo &&= foo;
foo ||= foo;
foo ??= foo;

此规则的正确代码示例

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

foo = bar;
[a, b] = [b, a];

// This pattern is warned by the `no-use-before-define` rule.
let foo = foo;

// The default values have an effect.
[foo = 1] = [foo];

// non-self-assignments with properties.
obj.a = obj.b;
obj.a.b = obj.c.b;
obj.a.b = obj.a.c;
obj[a] = obj["a"];

// This ignores if there is a function call.
obj.a().b = obj.a().b;
a().b = a().b;

// `&=` and `|=` have an effect on non-integers.
foo &= foo;
foo |= foo;

// Known limitation: this does not support computed properties except single literal or single identifier.
obj[a + b] = obj[a + b];
obj["a" + "b"] = obj["a" + "b"];

选项

此规则可以选择检查属性。

{
    "no-self-assign": ["error", {"props": true}]
}
  • props - 如果为 true,则 no-self-assign 规则会警告属性的自身赋值。默认为 true

props

使用 { "props": false } 选项的正确代码示例

在 Playground 中打开
/*eslint no-self-assign: ["error", {"props": false}]*/

// self-assignments with properties.
obj.a = obj.a;
obj.a.b = obj.a.b;
obj["a"] = obj["a"];
obj[a] = obj[a];

何时不使用它

如果您不想收到关于自身赋值的通知,则可以安全地禁用此规则。

版本

此规则在 ESLint v2.0.0-rc.0 中引入。

资源

更改语言