在线文档教程
Eslint
规则 | Rules

multiline-ternary

在三元表达式的操作数之间强制或禁止换行符(多行 - 三元)

JavaScript允许三元表达式的操作数被换行符隔开,这可以提高程序的可读性。

例如:

var foo = bar > baz ? value1 : value2;

为了提高可读性并更清楚地描述操作数,上面可以重写为以下内容:

var foo = bar > baz ? value1 : value2;

规则细节

此规则强制或禁止三元表达式的操作数之间的换行符。注意:此规则不强制执行操作员的位置。如果您有兴趣自行强制执行运营商的位置,请参阅运营商换行规则。

选项

这条规则有一个字符串选项:

  • "always" (默认)在三元表达式的操作数之间强制换行。

  • "always-multiline" 如果表达式跨越多行,则在三元表达式的操作数之间强制执行换行符。

  • "never" 不允许三元表达式的操作数之间的换行符(强制整个三元表达式在一行上)。

总是

这是默认选项。

此规则的错误代码示例包含以下"always"选项:

/*eslint multiline-ternary: ["error", "always"]*/ foo > bar ? value1 : value2; foo > bar ? value : value2; foo > bar ? value : value2;

此规则的正确代码示例包含以下"always"选项:

/*eslint multiline-ternary: ["error", "always"]*/ foo > bar ? value1 : value2; foo > bar ? (baz > qux ? value1 : value2) : value3;

always-multiline

此规则的错误代码示例包含以下"always-multiline"选项:

/*eslint multiline-ternary: ["error", "always-multiline"]*/ foo > bar ? value1 : value2; foo > bar ? value1 : value2; foo > bar && bar > baz ? value1 : value2;

此规则的正确代码示例包含以下"always-multiline"选项:

/*eslint multiline-ternary: ["error", "always-multiline"]*/ foo > bar ? value1 : value2; foo > bar ? value1 : value2; foo > bar ? (baz > qux ? value1 : value2) : value3; foo > bar ? (baz > qux ? value1 : value2) : value3; foo > bar && bar > baz ? value1 : value2;

never

此规则的错误代码示例包含以下"never"选项:

/*eslint multiline-ternary: ["error", "never"]*/ foo > bar ? value : value2; foo > bar ? value : value2; foo > bar ? value1 : value2;

此规则的正确代码示例包含以下"never"选项:

/*eslint multiline-ternary: ["error", "never"]*/ foo > bar ? value1 : value2; foo > bar ? (baz > qux ? value1 : value2) : value3;

何时不使用它

如果您没有任何有关三元表达式的操作数是否应以换行符分隔的严格约定,则可以安全地禁用此规则。

相关规则

  • operator-linebreakCompatibility

  • JSCS: requireMultiLineTernary

版本

这条规则是在ESLint 3.1.0中引入的。

资源