object-property-newline
强制将对象属性放在单独的行上
此规则报告的一些问题可以通过 --fix
命令行 选项自动修复
此规则已在 ESLint v8.53.0 中**弃用**。请使用 相应的规则 在 @stylistic/eslint-plugin-js
中。
此规则允许您限制对象文字中属性规范的位置。您可以禁止任何属性规范的任何部分出现在与任何其他属性规范的任何部分相同的行上。您可以使此禁止绝对化,或者,通过调用对象选项,您可以允许一个例外,允许对象文字的所有属性规范的所有部分都位于同一行上。
规则详情
动机
此规则可以确保(某些样式指南要求)属性规范出现在单独的行上以提高可读性。例如,您可以禁止所有这些
const newObject = {a: 1, b: [2, {a: 3, b: 4}]};
const newObject = {
a: 1, b: [2, {a: 3, b: 4}]
};
const newObject = {
a: 1,
b: [2, {a: 3, b: 4}]
};
const newObject = {
a: 1,
b: [
2,
{a: 3, b: 4}
]
};
而不是这些,您可以通过编写以下内容来遵守规则
const newObject = {
a: 1,
b: [2, {
a: 3,
b: 4
}]
};
或
const newObject = {
a: 1,
b: [
2,
{
a: 3,
b: 4
}
]
};
此规则的另一个好处是在更改属性时差异的特定性
// More specific
var obj = {
foo: "foo",
- bar: "bar",
+ bar: "bazz",
baz: "baz"
};
// Less specific
-var obj = { foo: "foo", bar: "bar", baz: "baz" };
+var obj = { foo: "foo", bar: "bazz", baz: "baz" };
可选异常
该规则提供了一个对象选项,allowAllPropertiesOnSameLine
(一个已弃用的同义词是 allowMultiplePropertiesPerLine
)。如果将其设置为 true
,则上面前两个对象文字(所有属性规范都在同一行上)将被允许,但类似于
const newObject = {
a: 'a.m.', b: 'p.m.',
c: 'daylight saving time'
};
将被禁止,因为两个属性(但不是所有属性)出现在同一行上。
符号
此规则平等地应用于所有属性规范,无论符号如何,包括
a: 1
(ES5)a
(ES2015 简写属性)[`prop${a}`]
(ES2015 计算属性名)
因此,该规则(没有可选异常)禁止这两个
const newObject = {
a: 1, [
process.argv[4]
]: '01'
};
const newObject = {
a: 1, [process.argv[4]]: '01'
};
(此行为与下面引用的 JSCS 规则的行为不同,该规则不将计算属性名的前导 [
视为该属性规范的一部分。JSCS 规则禁止第二种格式,但允许第一种格式。)
多行属性
该规则禁止在一个属性规范的至少 1 个字符与任何其他属性规范的至少 1 个字符在同一行上并置。例如,该规则禁止
const newObject = {a: [
'Officiële website van de Europese Unie',
'Официален уебсайт на Европейския съюз'
], b: 2};
因为 a
的规范的 1 个字符(即其值的尾随 ]
)与 b
的规范在同一行上。
可选异常不会原谅这种情况,因为整个属性规范集合跨越 4 行,而不是 1 行。
属性间分隔符
逗号和分隔属性规范的任何空格不被视为其一部分。因此,该规则允许这两种格式
const newFunction = multiplier => ({
a: 2 * multiplier,
b: 4 * multiplier,
c: 8 * multiplier
});
const newFunction = multiplier => ({
a: 2 * multiplier
, b: 4 * multiplier
, c: 8 * multiplier
});
(此行为与下面引用的 JSCS 规则的行为不同,该规则允许第一种格式但禁止第二种格式。)
–fix
如果此规则与命令行 --fix
选项一起调用,则违反该规则的对象文字通常会被修改以符合该规则。每种情况下的修改都是将属性规范移动到下一行,只要在同一行上有前一个属性规范的部分或全部。例如,
const newObject = {
a: 'a.m.', b: 'p.m.',
c: 'daylight saving time'
};
转换为
const newObject = {
a: 'a.m.',
b: 'p.m.',
c: 'daylight saving time'
};
修改不依赖于对象选项是否设置为 true
。换句话说,即使对象选项允许这样做,ESLint 也永远不会将所有属性规范收集到一行上。
如果注释紧接在行上的第二个或后续属性规范之前,ESLint 不会纠正此规则的违规行为,因为 ESLint 无法确定将注释放在哪一行上。
如上所示,应用于此规则的 --fix
选项不符合其他规则(例如 indent
),但是,如果这些其他规则也生效,则该选项也会应用它们。
示例
此规则的错误代码示例,没有对象选项或 allowAllPropertiesOnSameLine
设置为 false
/*eslint object-property-newline: "error"*/
const obj0 = { foo: "foo", : "bar", : "baz" };
const obj1 = {
foo: "foo", : "bar", : "baz"
};
const obj2 = {
foo: "foo", : "bar",
baz: "baz"
};
const obj3 = {
[process.argv[3] ? "foo" : "bar"]: 0, : [
1,
2,
4,
8
]
};
const a = "antidisestablishmentarianistically";
const b = "yugoslavyalılaştırabildiklerimizdenmişsiniz";
const obj4 = {a, };
const domain = process.argv[4];
const obj5 = {
foo: "foo",
domain.includes(":") ? "complexdomain" : "simpledomain"
]: true};
此规则的正确代码示例,没有对象选项或 allowAllPropertiesOnSameLine
设置为 false
/*eslint object-property-newline: "error"*/
const obj1 = {
foo: "foo",
bar: "bar",
baz: "baz"
};
const obj2 = {
foo: "foo"
, bar: "bar"
, baz: "baz"
};
const user = process.argv[2];
const obj3 = {
user,
[process.argv[3] ? "foo" : "bar"]: 0,
baz: [
1,
2,
4,
8
]
};
使用 { "allowAllPropertiesOnSameLine": true }
选项的此规则的其他正确代码示例
/*eslint object-property-newline: ["error", { "allowAllPropertiesOnSameLine": true }]*/
const obj = { foo: "foo", bar: "bar", baz: "baz" };
const obj2 = {
foo: "foo", bar: "bar", baz: "baz"
};
const user = process.argv[2];
const obj3 = {
user, [process.argv[3] ? "foo" : "bar"]: 0, baz: [1, 2, 4, 8]
};
何时不使用它
如果您想逐案决定是否将属性规范放在单独的行上,可以关闭此规则。
兼容性
- JSCS:此规则提供了与 requireObjectKeysOnNewLine 的部分兼容性。
相关规则
版本
此规则是在 ESLint v2.10.0 中引入的。