版本

no-undef-init

禁止将变量初始化为 undefined

🔧 可修复

此规则报告的一些问题可以通过 --fix 命令行 选项自动修复。

在 JavaScript 中,声明但未初始化为任何值的变量会自动获得 undefined 的值。例如

var foo;

console.log(foo === undefined);     // true

因此,无需将变量初始化为 undefined,例如

var foo = undefined;

避免将变量初始化为 undefined 被认为是一种最佳实践。

规则详情

此规则旨在消除初始化为 undefinedvarlet 变量声明。

此规则的错误代码示例

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

var foo = undefined;
let bar = undefined;

此规则的正确代码示例

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

var foo;
let bar;

请注意,此规则不检查 const 声明、解构模式、函数参数和类字段。

此规则的其他正确代码示例

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

const foo = undefined;

let { bar = undefined } = baz;

[quux = undefined] = quuux;

(foo = undefined) => {};

class Foo {
    bar = undefined;
}

何时不使用它

有一种情况,初始化为 undefined 的行为与省略初始化不同,那就是 var 声明出现在循环内部时。例如

此规则的错误代码示例

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

for (i = 0; i < 10; i++) {
    var x = undefined;
    console.log(x);
    x = i;
}

在这种情况下,var x 被提升到循环之外,实际上创建了

var x;

for (i = 0; i < 10; i++) {
    x = undefined;
    console.log(x);
    x = i;
}

如果要删除初始化,则循环的行为会发生变化

for (i = 0; i < 10; i++) {
    var x;
    console.log(x);
    x = i;
}

此代码等效于

var x;

for (i = 0; i < 10; i++) {
    console.log(x);
    x = i;
}

这产生的结果与在循环中定义 var x = undefined 不同,因为 x 不再每次循环都重置为 undefined

如果您在循环中使用此类初始化,则应禁用此规则。

此规则的正确代码示例,因为它在特定行上被禁用

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

for (i = 0; i < 10; i++) {
    var x = undefined; // eslint-disable-line no-undef-init
    console.log(x);
    x = i;
}

版本

此规则在 ESLint v0.0.6 中引入。

资源

更改语言