[英]Operator Precedence with Ternary Conditional and Logical And operators in JavaScript
[英]Javascript ternary operator with two true (?) conditional operators
有人可以帮忙代替吗? 由 THEN 在下面的代码中好吗?
return e = this.checked ? i - n > 0 ? 0 : i - n < 10 ? 10 : i - n : i - n < 0 ? 10 : i - n > 10 ? 0 : 10 + i - n
我特别困惑? 其次是另一个? 在语句的开头return e = this.checked ? i - n > 0 ? 0 .....
return e = this.checked ? i - n > 0 ? 0 .....
return e = this.checked ? i - n > 0 ? 0 .....
这意味着什么?
谢谢
插入括号和缩进,你的代码相当于:
return e = this.checked
? (
i - n > 0
? 0
: (
i - n < 10
? 10
: i - n
)
)
: (
i - n < 0
? 10
: (
i - n > 10
? 0
: 10 + i - n
)
);
简而言之,在第一个表达式或第二个表达式中,您可以嵌套更多的三元运算符,因为它们也解析为表达式 - 但是,这并不意味着这是一个好主意,它非常不可读。
使用 if-else 和这个工具:
if (this.checked) {
if (i - n > 0) {
return 0
} else {
if (i - n < 10) {
return 10
} else {
return i - n
}
}
} else {
if (i - n < 0) {
return 10
} else {
if (i - n > 10) {
return 0
} else {
return 10 + i - n
}
}
}
为了使其更具可读性,您始终可以将括号添加到您的代码中
return e = this.checked ? ( (i - n > 0 )? 0 : (i - n < 10 ? 10 : i - n ) ) : ( (i - n < 0) ? 10 : (i - n > 10 ? 0 : 10 + i - n) )
或分成单独的部分作为@Nick Parsons 的回答。
如果将三元分解为单独的部分,这可能会很有用。 本质上,它具有以下基本结构:
condition ? a : b
在这里, a
如果将执行condition
的计算结果为true
,且b
如果计算结果为将触发false
。
因此,将括号括在单独的三元运算符周围可以帮助解决问题。
return e = this.checked ? (i - n > 0 ? 0 : (i - n < 10 ? 10 : i - n)) : (i - n < 0 ? 10 : (i - n > 10 ? 0 : 10 + i - n))
所以在这里:
condition
是这样的。 this.checked
a
是(i - n > 0 ? 0 : (i - n < 10 ? 10 : i - n))
b
是(i - n < 0 ? 10 : (i - n > 10 ? 0 : 10 + i - n))
或者,如果将其转换为 if 语句,您可能会发现更容易理解,如下所示:
if (this.checked) {
if (i - n > 0) {
return 0
} else {
if (i - n < 10) {
return 10;
} else {
return i - n;
}
}
} else {
if (i - n < 0) {
return 10;
} else {
if (i - n > 10) {
return 0;
} else {
return 10 + i - n;
}
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.