switch语句中的常见情况

问题描述 投票:1回答:4

我需要执行常见案例然后执行具体案例,这就是我正在做的事情:

let array = ['foo', 'bar', 'baz'];

array.forEach(element => {
    switch (element) {
        case 'baz':
            console.log('its baz');
            break;
        case 'foo':
        case 'bar':
            console.log('its foo or bar');
        case 'foo':
            console.log('its foo');
            break;
        case 'bar':
            console.log('its bar');
            break;
        default:
            break;
    }
});

输出:

its foo or bar
its foo
its foo or bar
its foo // expected: 'its bar'
its baz

它适用于foo但不适用于bar。我错过了什么?

javascript switch-statement
4个回答
3
投票

Switch-case以这种方式工作:控制从switch语句转移到第一个匹配,然后执行所有语句(包括来自其他情况的语句),直到遇到break语句。此行为称为fallthrough。

所以,每当这个案例被切换到时,

case 'foo':
case 'bar':
    console.log('its foo or bar');

这种情况总是被称为:

 case 'foo':
    console.log('its foo');

原因是在第一个片段之后没有break语句。因此,控件继续执行语句,直到遇到break语句。


2
投票

您正面临的情况的原因已由@SHRAIYSH解释。以下是您可能正在寻找的另一种解决方案

let array = ['foo', 'bar', 'baz'];

array.forEach(element => {
    switch (element) {
        case 'baz':
            console.log('its baz');
            break;
        case 'foo':
        case 'bar':
            console.log('its foo or bar');
            if(element==='foo'){
            	console.log('its inner foo');
            }else{
              console.log('its inner bar')
            }
        break;
        case 'foo':
            console.log('its foo');
            break;
        case 'bar':
            console.log('its bar');
            break;
        default:
            break;
    }
});

在处理switch声明时,它只能满足一个案例。因此,不使用仅满足foo的sideEffect,您可以在案例中使用另一个if else


0
投票

您必须使用2个嵌套的switch语句,如下所示:

let array = ['foo', 'bar', 'baz'];

array.forEach(element => {
    switch (element) {
        case 'baz':
            console.log('its baz');
            break;
        case 'foo':
        case 'bar':
             console.log('its foo or bar');
             switch (element) {
                 case 'foo':
                    console.log('its foo');
                    break;
                 case 'bar':
                    console.log('its bar');
                    break;
             }
        default:
            break;
    }
});

0
投票

试试这个 :)

let array = ['foo', 'bar', 'baz'];

array.forEach(element => {
    switch (element) {
        case 'baz':
            console.log('its baz');
            break;
        case 'foo':
        case 'bar':
            console.log('its foo or bar');
        case 'foo':
            if (element === 'foo')  {
                console.log('its foo');
                break;
            }
        case 'bar':
            console.log('its bar');
            break;
        default:
            break;
    }
});
© www.soinside.com 2019 - 2024. All rights reserved.