版本

no-multi-spaces

禁止使用多个空格

🔧 可修复

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

此规则在 ESLint v8.53.0 中已**弃用**。请使用 相应的规则@stylistic/eslint-plugin-js 中。

连续多个空格不用于缩进通常是错误。例如


if(foo  === "bar") {}

很难看出来,但在foo===之间有两个空格。通常不建议使用此类多个空格,而应使用单个空格。


if(foo === "bar") {}

规则详情

此规则旨在禁止在逻辑表达式、条件表达式、声明、数组元素、对象属性、序列和函数参数周围使用多个空格。

此规则的错误代码示例

在在线运行中打开
/*eslint no-multi-spaces: "error"*/

var a =  1;

if(foo   === "bar") {}

a <<  b

var arr = [1,  2];

a ?  b: c

此规则的正确代码示例

在在线运行中打开
/*eslint no-multi-spaces: "error"*/

var a = 1;

if(foo === "bar") {}

a << b

var arr = [1, 2];

a ? b: c

选项

此规则的配置由一个具有以下属性的对象组成

  • "ignoreEOLComments": true(默认为false)忽略行尾注释前的多个空格。
  • "exceptions": { "Property": true }"Property" 是默认指定的唯一节点)指定要忽略的节点。

ignoreEOLComments

使用{ "ignoreEOLComments": false }(默认)选项时,此规则的错误代码示例

在在线运行中打开
/*eslint no-multi-spaces: ["error", { ignoreEOLComments: false }]*/

var x = 5;      // comment
var x = 5;      /* multiline
 * comment
 */

使用{ "ignoreEOLComments": false }(默认)选项时,此规则的正确代码示例

在在线运行中打开
/*eslint no-multi-spaces: ["error", { ignoreEOLComments: false }]*/

var x = 5; // comment
var x = 5; /* multiline
 * comment
 */

使用{ "ignoreEOLComments": true }选项时,此规则的正确代码示例

在在线运行中打开
/*eslint no-multi-spaces: ["error", { ignoreEOLComments: true }]*/

var x = 5; // comment
var x = 5;      // comment
var x = 5; /* multiline
 * comment
 */
var x = 5;      /* multiline
 * comment
 */

exceptions

为了避免与需要多个空格的其他规则发生冲突,此规则有一个exceptions选项来忽略某些节点。

此选项是一个对象,它期望属性名称为由ESTree定义的 AST 节点类型。确定exceptions的节点类型的最简单方法是使用带有 espree 解析器的AST Explorer

默认情况下,只有Property节点类型被忽略,因为对于key-spacing规则,某些对齐选项需要在对象文字的属性中使用多个空格。

默认"exceptions": { "Property": true }选项的正确代码示例

在在线运行中打开
/*eslint no-multi-spaces: "error"*/
/*eslint key-spacing: ["error", { align: "value" }]*/

var obj = {
    first:  "first",
    second: "second"
};

"exceptions": { "Property": false }选项的错误代码示例

在在线运行中打开
/*eslint no-multi-spaces: ["error", { exceptions: { "Property": false } }]*/
/*eslint key-spacing: ["error", { align: "value" }]*/

var obj = {
    first:  "first",
    second: "second"
};

"exceptions": { "BinaryExpression": true }选项的正确代码示例

在在线运行中打开
/*eslint no-multi-spaces: ["error", { exceptions: { "BinaryExpression": true } }]*/

var a = 1  *  2;

"exceptions": { "VariableDeclarator": true }选项的正确代码示例

在在线运行中打开
/*eslint no-multi-spaces: ["error", { exceptions: { "VariableDeclarator": true } }]*/

var someVar      = 'foo';
var someOtherVar = 'barBaz';

"exceptions": { "ImportDeclaration": true }选项的正确代码示例

在在线运行中打开
/*eslint no-multi-spaces: ["error", { exceptions: { "ImportDeclaration": true } }]*/

import mod          from 'mod';
import someOtherMod from 'some-other-mod';

何时不使用它

如果您不想检查和禁止使用多个空格,则应关闭此规则。

版本

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

资源

更改语言