zoukankan      html  css  js  c++  java
  • js中switch语句不执行

    参考http://www.jb51.net/article/54393.htm

    switch语句与if语句的关系最为密切,也是其它编程语言中普遍使用的一种流程控制语句,但switch的匹配是全等模式,如果不注意这个细节则写程序时往往会出错。

    代码:

    1
    2
    3
    4
    5
    6
    7
    8
    var n = '5';
    switch(n){
        case 5:
            alert('执行case分支');
            break;
        default:
            alert('执行default分支');
    }

    结果:

    JS中的switch

    可能很多人会误以为以上程序会走case分支,结果却走了default分支。难道它们两个不相等吗?我们使用if语句看看。

    代码:

    1
    2
    3
    4
    5
    6
    var n = '5';
    if(n==5){
        alert('真 分支');
    }else{
        alert('假 分支');
    }

    结果:

    JS中的switch

    在if语句里可以匹配,但为何在switch语句里不能匹配呢?

    这是因为在switch语句里的case使用全等模式,也就相当于if里的使用三个等号类似。我们把case的代码改写一下

    代码:

    1
    2
    3
    4
    5
    6
    7
    8
    var n = '5';
    switch(n){
        case '5': // 把原来的 case 5 改写成 case '5'
            alert('执行case分支');
            break;
        default:
            alert('执行default分支');
    }

    结果:

    JS中switch

    改写了以后就能走case分支了,就像我们if里使用三个全等号一样

    代码:

    1
    2
    3
    4
    5
    6
    var n = '5';
    if(n===5){
        alert('真 分支');
    }else{
        alert('假 分支');
    }

    结果:

    JS中的switch

    因为使用全等,所以字符串5不等于数字5,结果走了假分支。

    由以上例子说明在 switch中使用的是全等匹配模式,特别是数字与字符串匹配的时候需要注意的一个问题

    最后我将数字改为字符串类型后,程序跑起来了。

     //开始加密
        var currvalue = $("#select  option:selected").val();
        switch(currvalue)
        {
            case '0':
               //base64
                var b = new Base64();
                name = new Base64().encode(name);
                //解密
                //var str = b.decode(str);
                break;
            case '1':
               //md5
                
                
                break;
            case '2':
               //sha1
                
                
                break;
            default:
                //des
                
                
        }
        alert(name);

  • 相关阅读:
    iOS 自动化测试踩坑(二):Appium 架构原理、环境命令、定位方式
    干货 | 掌握 Selenium 元素定位,解决 Web 自动化测试痛点
    代理技术哪家强?接口 Mock 测试首选 Charles
    浅谈MVC缓存
    PetaPoco 快速上手
    解释器模式(26)
    享元模式(25)
    中介者模式(24)
    职责链模式(23)
    命令模式(22)
  • 原文地址:https://www.cnblogs.com/dqcer/p/7598653.html
Copyright © 2011-2022 走看看