преобразовать вложенные операторы if в более элегантный переключатель? - PullRequest
1 голос
/ 18 июня 2011

как я могу преобразовать этот вложенный оператор if во что-то более читаемое и «элегантное»?

if(speed==0){
            othvalue=0;
        }else {
            if(speed>value1864cmn){
                othvalue=value1864cmn;
            }else {
                if(speed>value1746cmn){
                    othvalue=value1746cmn;
                }else {
                    if(speed>value1628cmn){
                        othvalue=value1628cmn;
                    }else {
                        if(speed>value1510cmn){
                            othvalue=value1510cmn;
                        }else {
                            if(speed>value1392cmn){
                                othvalue=value1392cmn;
                            }else {
                                if(speed>value1274cmn){
                                    othvalue=value1274cmn;
                                }else {
                                    if(speed>value1156cmn){
                                        othvalue=value1156cmn;
                                    }else {
                                        if(speed>value1038cmn){
                                            othvalue=value1038cmn;
                                        }else {
                                            if(speed>value920cmn){
                                                othvalue=value920cmn;
                                            }
                                        }
                                    }
                                }
                            }
                        }
                    }
                }
            }
        };

Ответы [ 5 ]

5 голосов
/ 18 июня 2011

Вы можете использовать конструкцию "match":

var othvalue = (speed == 0) ? 0 
             : (speed <= 10) ? 10
             : (speed <= 20) ? 20
             : (speed <= 30) ? 30
             : 40;
3 голосов
/ 18 июня 2011

Вам не нужно ни вкладывать это, ни преобразовывать его в оператор switch.Просто поместите if прямо рядом с else.

Например:

if(speed==0){
    othvalue=0;
} else if(speed>value1864cmn){
    othvalue=value1864cmn;
} else if {
...
1 голос
/ 18 июня 2011

// Я не знаю, как изящно, но пошагово пройти через массив довольно быстро.

function setSpeedValue(speed){
    var L= 9, values= [0, 920, 1038, 1156, 1274, 1392, 1510, 1628, 1746, 1864];
    while(values[L]>speed)--L;
    return 'value'+values[L]+'cmn';
}
alert(setSpeedValue(1040))
1 голос
/ 18 июня 2011
if (speed == 0) {
    othvalue = 0;
} else {
    var values = [
        value1746cmn, value1628cmn, value1510cmn, value1392cmn, value1274cmn,
        value1156cmn, value1038cmn, value920cmn
    ];
    for (var i in values) {
        if (speed > values[i]) {
            othvalue = values[i];
            break;
        }
    }
}
1 голос
/ 18 июня 2011
if (speed == 0) {
    othvalue = 0;
} else if (speed > value1864cmn) {
    othvalue = value1864cmn;
} else if (speed > value1746cmn) {
    othvalue = value1746cmn;
} else if (speed > value1628cmn) {
    othvalue = value1628cmn;
} else if (speed > value1510cmn) {
    othvalue = value1510cmn;
} else if (speed > value1392cmn) {
    othvalue = value1392cmn;
} else if (speed > value1274cmn) {
    othvalue = value1274cmn;
} else if (speed > value1156cmn) {
    othvalue = value1156cmn;
} else if (speed > value1038cmn) {
    othvalue = value1038cmn;
} else if (speed > value920cmn) {
    othvalue = value920cmn;
};
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...