版本

array-bracket-newline

强制在数组括号的开头和结尾处换行

🔧 可修复

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

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

许多风格指南要求或禁止在数组括号内换行。

规则详情

此规则强制在数组括号的开头和结尾处换行。

选项

此规则具有字符串选项

  • "always" 要求在括号内换行
  • "never" 禁止在括号内换行
  • "consistent" 要求每对括号的一致换行使用。如果一对括号中一个括号在内部换行而另一个括号没有,则会报告错误。

或对象选项(如果满足任何属性,则要求换行。否则,禁止换行)

  • "multiline": true(默认值)如果元素内部或元素之间有换行符,则要求换行。如果为 false,则禁用此条件。
  • "minItems": null(默认值)如果元素数量至少为给定的整数,则要求换行。如果为 0,则此条件的作用与选项"always"相同。如果为null(默认值),则禁用此条件。

always

使用"always"选项时,此规则的错误代码示例

在代码游乐场中打开
/*eslint array-bracket-newline: ["error", "always"]*/

var a = [];
var b = [1];
var c = [1, 2];
var d = [1,
    2];
var e = [function foo() {
    dosomething();
}];

使用"always"选项时,此规则的正确代码示例

在代码游乐场中打开
/*eslint array-bracket-newline: ["error", "always"]*/

var a = [
];
var b = [
    1
];
var c = [
    1, 2
];
var d = [
    1,
    2
];
var e = [
    function foo() {
        dosomething();
    }
];

never

使用"never"选项时,此规则的错误代码示例

在代码游乐场中打开
/*eslint array-bracket-newline: ["error", "never"]*/

var a = [
];
var b = [
    1
];
var c = [
    1, 2
];
var d = [
    1,
    2
];
var e = [
    function foo() {
        dosomething();
    }
];

使用"never"选项时,此规则的正确代码示例

在代码游乐场中打开
/*eslint array-bracket-newline: ["error", "never"]*/

var a = [];
var b = [1];
var c = [1, 2];
var d = [1,
    2];
var e = [function foo() {
    dosomething();
}];

consistent

使用"consistent"选项时,此规则的错误代码示例

在代码游乐场中打开
/*eslint array-bracket-newline: ["error", "consistent"]*/

var a = [1
];
var b = [
    1];
var c = [function foo() {
    dosomething();
}
]
var d = [
    function foo() {
        dosomething();
    }]

使用"consistent"选项时,此规则的正确代码示例

在代码游乐场中打开
/*eslint array-bracket-newline: ["error", "consistent"]*/

var a = [];
var b = [
];
var c = [1];
var d = [
    1
];
var e = [function foo() {
    dosomething();
}];
var f = [
    function foo() {
        dosomething();
    }
];

multiline

使用默认{ "multiline": true }选项时,此规则的错误代码示例

在代码游乐场中打开
/*eslint array-bracket-newline: ["error", { "multiline": true }]*/

var a = [
];
var b = [
    1
];
var c = [
    1, 2
];
var d = [1,
    2];
var e = [function foo() {
    dosomething();
}];

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

在代码游乐场中打开
/*eslint array-bracket-newline: ["error", { "multiline": true }]*/

var a = [];
var b = [1];
var c = [1, 2];
var d = [
    1,
    2
];
var e = [
    function foo() {
        dosomething();
    }
];

minItems

使用{ "minItems": 2 }选项时,此规则的错误代码示例

在代码游乐场中打开
/*eslint array-bracket-newline: ["error", { "minItems": 2 }]*/

var a = [
];
var b = [
    1
];
var c = [1, 2];
var d = [1,
    2];
var e = [
  function foo() {
    dosomething();
  }
];

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

在代码游乐场中打开
/*eslint array-bracket-newline: ["error", { "minItems": 2 }]*/

var a = [];
var b = [1];
var c = [
    1, 2
];
var d = [
    1,
    2
];
var e = [function foo() {
    dosomething();
}];

multiline 和 minItems

使用{ "multiline": true, "minItems": 2 }选项时,此规则的错误代码示例

在代码游乐场中打开
/*eslint array-bracket-newline: ["error", { "multiline": true, "minItems": 2 }]*/

var a = [
];
var b = [
    1
];
var c = [1, 2];
var d = [1,
    2];
var e = [function foo() {
    dosomething();
}];

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

在代码游乐场中打开
/*eslint array-bracket-newline: ["error", { "multiline": true, "minItems": 2 }]*/

var a = [];
var b = [1];
var c = [
    1, 2
];
var d = [
    1,
    2
];
var e = [
    function foo() {
        dosomething();
    }
];

何时不使用它

如果您不想强制在数组括号的开头和结尾处换行,请不要启用此规则。

兼容性

版本

此规则是在 ESLint v4.0.0-alpha.1 中引入的。

资源

更改语言