JS三元运营商混乱

时间:2012-01-18 20:07:33

标签: javascript operator-keyword ternary

我现在正在学习三元运算符。我得到了基础知识,但后来我看到了这个片段,这对我没有任何意义。任何人都可以解释它是如何组合在一起的?!

b.m & 4 || (c |= 2, 63 <= a && 77 >= a ? a = 65 : 48 <= a && 57 >= a ? a = 48 : c & 1 ? 97 <= a && 122 >= a ? a = 65 : 197 == a || 229 == a ? c &= 5 : 192 <= a && 687 >= a ? a = 192 : 1536 <= a ? a = 1536 : 912 <= a ? a = 912 : 160 <= a ? a = 160 : 127 <= a ? c &= 5 : 33 <= a ? a = 59 : c &= 5 : 48 > a ? c &= 5 : 65 > a ? a = 59 : 96 > a ? c &= 5 : 112 > a ? a = 96 : 187 > a ? c &= 5 : a = 59);

b.m&amp; 4 || 就我所理解的是位操作,然后(c | = 2,另一位操作,但是逗号是什么意思?!

然后就是 63&lt; =&amp;&amp; 77&gt; = a? a = 65:48

转换为

  

if(a> = 63&amp;&amp; a&lt; = 77){   a = 65   } else {   a = 48;   }

之后&lt; = a&amp;&amp; 57&gt; = a? a = 48:c&amp; 1? 97&lt; = a 对我来说根本没有任何意义。因为48是前一个声明。任何人都可以

3 个答案:

答案 0 :(得分:7)

逗号是javascript中的单独operator

  

逗号运算符计算其两个操作数(从左到右)   并返回第二个操作数的值。

你只掌握了表达的一部分:

  

然后有63&lt; = a&amp;&amp; 77&gt; = a? a = 65:48

实际上它有点长(有一些格式化):

63 <= a && 77 >= a
    ? a = 65
    : 48 <= a && 57 >= a
        ? a = 48
        : c & 1
            ? 97 <= a && 122 >= a
                ? a = 65
                : 197 == a || 229 == a
                    ? c &= 5
                    : 192 <= a && 687 >= a
                        ? a = 192
                        : 1536 <= a
                            ? a = 1536
                            : 912 <= a
                                ? a = 912
                                : 160 <= a
                                    ? a = 160
                                    : 127 <= a
                                        ? c &= 5
                                        : 33 <= a
                                            ? a = 59
                                            : c &= 5
            : 48 > a
                ? c &= 5
                : 65 > a
                    ? a = 59
                    : 96 > a
                        ? c &= 5
                        : 112 > a
                            ? a = 96
                            : 187 > a
                                ? c &= 5
                                : a = 59

尝试在if-else中重写它会产生以下结果:

if (63 <= a && 77 >= a){
    a = 65
} else if (48 <= a && 57 >= a){
    a = 48
} else if (c & 1){
    if (97 <= a && 122 >= a){
        a = 65
    } else if (197 == a || 229 == a){
        c &= 5
    } else if (192 <= a && 687 >= a){
        a = 192
    } else if (1536 <= a){
        a = 1536
    } else if (912 <= a){
        a = 912
    } else if (160 <= a){
        a = 160
    } else if (127 <= a){
        c &= 5
    } else if (33 <= a){
        a = 59
    } else {
        c &= 5
    }               
} else {
    if (48 > a){
        c &= 5
    } else if (65 > a){
        a = 59
    } else if (96 > a){
        c &= 5
    } else if (112 > a){
        a = 96
    } else if (187 > a){
        c &= 5
    } else {
        a = 59
    }
}

注意 if-else方法当前缺少返回值,而三元运算符确实返回执行的最后一个运算符的值(这可能会影响括号中布尔表达式的整体值)。

答案 1 :(得分:2)

我更喜欢格式化嵌套的三元语句like this,因此它们具有简单易读的结构:

//   (is this true) ? then do this  
//   (is this true) ? then do this  
// (all else fails) : then do this

遵循该结构,它看起来像这样:

  63 <= a && 77 >= a ? a = 65
: 48 <= a && 57 >= a ? a = 48
:              c & 1 ? /* then go into this indented block below */
                         97 <= a && 122 >= a ? a = 65
:                       197 == a || 229 == a ? c &= 5
:                       192 <= a && 687 >= a ? a = 192
:                                  1536 <= a ? a = 1536
:                                   912 <= a ? a = 912
:                                   160 <= a ? a = 160
:                                   127 <= a ? c &= 5
:                                    33 <= a ? a = 59
                                  /* else */ : c &= 5
:            48 > a ? c &= 5
:            65 > a ? a = 59
:            96 > a ? c &= 5
:           112 > a ? a = 96
:           187 > a ? c &= 5
   /* final else */ : a = 59

答案 2 :(得分:1)

逗号不是三元运算符,它允许两个表达式替换一个。

但更重要的是,那是一团糟。分解,格式化并评论它。除非你打高尔夫球,否则将所有这些组合成一堆只是辱骂。