0

我找到了这篇文章:Switch case with three parameters? 我正在考虑使用 switch case 传递多个参数,如下所示:

switch (array($var1, $var2, $var3)) {
case array(true, false, false):
    echo "hello";
    break;
}

关于这是否是最有效的方法似乎存在一些问题。情绪似乎是 if 条件更合适。但是,当我看到我正在写的条件时,我不确定?例如,这感觉很乱(请注意,我已经删除了大约 6 个其他条件,以免让您感到无聊):

if ( 
  csz == "google" || 
  csz == "bing" || 
  csz == "yahoo" || 
  csz == "dogpile" || 
  csz == "millionshort" && 
  cs == '' ) { 
    $("li.phone").replaceWith('<li class="phone">' + phoneNaturalSearch + '</li>');
}
else if ( 
  csz == "facebook" && 
  cs == '' ) { 
    $("li.phone").replaceWith('<li class="phone">' + phoneFacebook + '</li>');
}
else if ( 
  csz == "google-plus" || 
  csz == "plus" ) { 
    $("li.phone").replaceWith('<li class="phone">' + phoneGooglePlus + '</li>');
}
// Snipped out other conditionals
else { 
    $("li.phone").replaceWith('<li class="phone">' + phoneDefault + '</li>');
}

在这里使用多个参数进行切换会更有效,还是会遇到性能下降?我想我应该编写代码,看看它是否真的不那么混乱,但我想我会先把它从大师那里反弹。

4

2 回答 2

5

我觉得如果你有这么多条件,我更喜欢使用 switch 语句,这使你的代码更清晰,更容易理解。你可以省略掉属于这个特定类别的条件的 break ......

var phoneType= '';

switch(csz){ 
  case "google" : 
  case  "bing" : 
  case "yahoo" :
  case "dogpile"  : 
  case "millionshort" : 
    if (cs==''){ 
        phoneType = phoneNaturalSearch ;
        break;
    }
    else {
        goto case "facebook";
    }
  case "facebook" :
    if (cs==''){ 
        phoneType = phoneFacebook  ;
        break;
    }
    else {
        goto case "google-plus";
    }
  case "google-plus" :
  case "plus"  : 
    phoneType = phoneGooglePlus ;
    break;
  default : 
    phoneType = phoneDefault  ;
    break;
}

$("li.phone").replaceWith('<li class="phone">' + phoneType + '</li>');
于 2012-09-07T16:17:32.007 回答
0

谈到更整洁的解决方案,另一种方法是将它们保存在二维数组中并检索元素索引。

看一下这个 :

var csz= 'amazon';

var groups = [['google','yahoo','bing'],['facebook','orkut','hi5','zurker'],['amazon','bestbuy','sears']];
var groupIndex = getIndexOf(groups,csz);
if(groupIndex ==1){
    //code here
    alert("1");
}else if(groupIndex ==2){
    //code here
    alert("2");
}else if(groupIndex ==3){
    //code here
    alert("3");
}

function getIndexOf(myArray,element){
    for(var i=0;i<groups.length;i++){
        for(var j=0;j<groups[i].length;j++){
            if(myArray[i][j]==element){
                return i;  
            }
        }
    }        
    return -1;
}
于 2012-09-07T18:50:34.830 回答