版本

no-void

禁用 void 运算符

❄️ 已冻结

此规则当前已冻结,并且不接受功能请求。

void 运算符接受一个操作数并返回 undefinedvoid expression 将会执行 expression 并返回 undefined。它可以用于忽略 expression 可能产生的任何副作用

使用 void 运算符的常见情况是获取一个“纯粹”的 undefined 值,因为在 ES5 之前,undefined 变量是可变的

// will always return undefined
(function(){
    return void 0;
})();

// will return 1 in ES3 and undefined in ES5+
(function(){
    undefined = 1;
    return undefined;
})();

// will throw TypeError in ES5+
(function(){
    'use strict';
    undefined = 1;
})();

另一个常见的情况是压缩代码,因为 void 0undefined 更短

foo = void 0;
foo = undefined;

当与 IIFE(立即调用函数表达式)一起使用时,void 可以用于强制将 function 关键字视为表达式而不是声明

let foo = 1;
void function(){ foo = 1; }() // will assign foo a value of 1
+function(){ foo = 1; }() // same as above
function(){ foo = 1; }() // will throw SyntaxError

某些代码风格禁止 void 运算符,认为它不明显且难以阅读。

规则详情

此规则旨在消除 void 运算符的使用。

此规则的错误代码示例

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

void foo
void someFunction();

const foo = void bar();
function baz() {
    return void 0;
}

选项

此规则有一个对象选项

  • allowAsStatement 设置为 true 允许将 void 运算符用作语句(默认为 false)。

allowAsStatement

allowAsStatement 设置为 true 时,该规则不会对将 void 运算符用作语句的情况报错,即当它不用于表达式位置时,例如在变量赋值或函数返回中。

{ "allowAsStatement": true }错误代码示例

在 Playground 中打开
/*eslint no-void: ["error", { "allowAsStatement": true }]*/

const foo = void bar();
function baz() {
    return void 0;
}

{ "allowAsStatement": true }正确代码示例

在 Playground 中打开
/*eslint no-void: ["error", { "allowAsStatement": true }]*/

void foo;
void someFunction();

何时不使用

如果您有意使用 void 运算符,则可以禁用此规则。

版本

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

延伸阅读

资源

更改语言