我可以使用带有两个变量的case / switch语句吗?

时间:2012-02-10 21:36:39

标签: javascript switch-statement case

对于JavaScript来说,我是一个新手,我的理解是使用一个SWITCH / CASE语句比一大堆IF语句更快。

但是,我想使用带有两个变量的SWITCH / CASE语句。

我的网络应用有两个滑块,每个滑块有五种状态。我希望行为基于这两个变量的状态。很明显,这是很多IF / THEN陈述的全部内容。

我想到的一种方法是将两个变量连接成一个然后我可以SWITCH / CASE。

使用两个变量是否有更好的方法来完成SWITCH / CASE?

谢谢!

9 个答案:

答案 0 :(得分:20)

按位运算符怎么样?而不是字符串,你正在处理“enums”,它看起来更“优雅。”

// Declare slider's state "enum"
var SliderOne = {
    A: 1,
    B: 2,
    C: 4,
    D: 8,
    E: 16
};

var SliderTwo = {
    A: 32,
    B: 64,
    C: 128,
    D: 256,
    E: 512
};

// Set state
var s1 = SliderOne.A,
    s2 = SliderTwo.B;

// Switch state
switch (s1 | s2) {
    case SliderOne.A | SliderTwo.A :
    case SliderOne.A | SliderTwo.C :
        // Logic when State #1 is A, and State #2 is either A or C
        break;
    case SliderOne.B | SliderTwo.C :
        // Logic when State #1 is B, and State #2 is C
        break;
    case SliderOne.E | SliderTwo.E :
    default:
        // Logic when State #1 is E, and State #2 is E or
        // none of above match
        break;


}

我同意其他人的观点,25个案例中的案例逻辑并不太漂亮,而且在某些情况下,如果“其他”可能“看起来”更好。反正。

答案 1 :(得分:18)

var var1 = "something";
var var2 = "something_else";
switch(var1 + "|" + var2) {
    case "something|something_else":
        ...
        break;
    case "something|...":
        break;
    case "...|...":
        break;
}

如果您有5种可能性,那么您将得到25个案例。

答案 2 :(得分:9)

首先,JavaScript's switch is no faster than if/else (and sometimes much slower)

其次,将switch与多个变量一起使用的唯一方法是将它们组合成一个基元(字符串,数字等)值:

var stateA = "foo";
var stateB = "bar";
switch (stateA + "-" + stateB) {
    case "foo-bar": ...
    ...
}

但是,就个人而言,我希望看到一组if / else声明。

修改:当所有值都是整数时,如果Chrome中的/ else显示切换可能会超出。见评论。

答案 3 :(得分:4)

我不相信开关/案例比if / elseif系列更快。他们做同样的事情,但如果/ elseif你可以检查多个变量。您不能在多个值上使用开关/案例。

答案 4 :(得分:3)

您可以为每个滑块上的每个位置指定1到1000000000的不同二进制值 然后使用总和。

答案 5 :(得分:3)

如果每个组合的动作是静态的,您可以构建一个二维数组:

var data = [
  [1,2,3,4,5],
  [6,7,8,9,10],
  [11,12,13,14,15],
  [16,17,18,19,20],
  [21,22,23,24,25]
];

上面示例中的数字可以是任何内容,例如字符串,数组等。获取值现在是一个单行(假设滑块的值范围为[0,5]:

var info = data[firstSliderValue][secondSliderValue];

答案 6 :(得分:1)

是的,但不是正常的方式。你必须使用switch作为闭包。

例如: -

function test(input1, input2) {
     switch (true) {
        case input1 > input2:
                    console.log(input1 + " is larger than " + input2);
                    break;
        case input1 < input2:
                    console.log(input2 + " is larger than " + input1);
        default:
                    console.log(input1 + " is equal to " + input2);
      }
   }

答案 7 :(得分:0)

是的,您也可以这样做:

    switch (true) {

     case (var1 === true && var2 === true) :
       //do something
       break;
     case (var1 === false && var2 === false) :
       //do something
       break;

      default:

    }

这将始终执行切换,几乎与if / else一样,但看起来更干净。只需继续检查案例表达式中的变量即可。

答案 8 :(得分:0)

像 scala&python 这样的语言为你提供了非常强大的东西,比如 patternMatching,不幸的是,这仍然是 Java 中缺少的功能......

但是有一个解决方案(在大多数情况下我不喜欢),您可以执行以下操作:

final int s1Value = 0;
final int s2Value = 0;
final String s1 = "a";
final String s2 = "g";

switch (s1 + s2 + s1Value + s2Value){
    case "ag00": return true;
    default: return false;
}