# multiline-ternary

在三元表达式的操作数之间强制换行

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

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

例如:

var foo = bar > baz ? value1 : value2;

上面可以改写如下,以提高可读性并更清楚地描述操作数:

var foo = bar > baz ?
    value1 :
    value2;

# 规则详情

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

# 选项

此规则有一个字符串选项:

  • "always"(默认)在三元表达式的操作数之间强制换行。
  • 如果表达式跨越多行,"always-multiline" 强制在三元表达式的操作数之间换行。
  • "never" 不允许在三元表达式的操作数之间换行。

# always

这是默认选项。

此规则使用 "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;

foo > bar ? (
    baz > qux ? value1 : value2
) : value3;

# 何时不使用

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

# 兼容性

  • JSCSrequireMultiLineTernary
Last Updated: 5/13/2023, 8:55:38 PM