我查看了Raphael.js
的源代码,以了解他是如何将RGB值转换为HSB值的。我找到了他使用的函数,我正在将其转换为Python时,我遇到了这个漂亮的三重嵌套三元运算符:
H = (C == 0 ? null :
V == r ? (g - b) / C :
V == g ? (b - r) / C + 2 :
(r - g) / C + 4
);
它让我大吃一惊,因为Python没有Javascript那样的三元运算符。我花了一段时间查看它,最终将这个更理智的代码(只使用if/else)散列出来:
if (C == 0) {
H = null;
} else {
if(V == r) {
H = (g - b) / C;
} else {
if(V == g) {
H = (b - r) / C + 2;
} else {
H = (r - g) / C + 4;
}
}
}
我的解释正确吗?我之所以这样问,是因为如果它不正确,我将面临大量的调试工作。所以。我“明白”了吗?
发布于 2012-05-10 10:26:34
我认为你可以这样做,以避免嵌套太深:
var H
if(C == 0){
H = null;
}
else if(V == r){
H = (g - b) / C;
}
else if (V == g){
H = (b - r) / C + 2;
}
else {
H = (r - g) / C + 4;
}
发布于 2016-09-03 03:00:55
在我个人看来,仔细对齐的嵌套三元结构胜过了if-else的混乱:
const H =
C == 0 ? null :
V == r ? (g - b) / C :
V == g ? (b - r) / C + 2 :
(r - g) / C + 4 ;
发布于 2012-05-10 10:27:04
同样的逻辑可以用一种更简单的方式编写:
var H
if (C == 0)
H = null;
else if (V == r)
H = (g - b) / C;
else if (V == g)
H = (b - r) / C + 2;
else
H = (r - g) / C + 4;
可以省略大括号,因为每个条件中都有一条语句。考虑到这些条件是互斥的,使用else if
比嵌套if
要清晰得多。
https://stackoverflow.com/questions/10526739
复制相似问题