很早以前就觉得switch很怪异,或者说一直没太理解它,它怪异就怪异在非要给每个语句加上break;不然后面的语句就算不符合条件还是会执行,比如以下这段代码

var num = 2;

switch(num){
case 1:
console.log(1);
case 2:
console.log(2);
case 3:
console.log(3);
case 4:
console.log(4);
}

执行效果如下

明明只有2才符合条件,但3跟4也被执行了,然后查教程说要加上break,后来代码就成了下面这个样子

var num = 2;

switch(num){
case 1:
console.log(1);
break;
case 2:
console.log(2);
break;
case 3:
console.log(3);
break;
case 4:
console.log(4);
break;
}

写过若干个switch语句以后,心里不由产生一种情绪,switch太TM难用了,明明很简单,非要让人多写一个break;还不如用if来判断,不知道这是不是很多人都有的想法,反正在之前我是这么想的。

写的代码越多,就越觉得这太不对劲了,于是在想,如果每个语句都要写break;那么解析器直接帮忙写上就好了,可现实是,解析器并没有这么干。在某一个瞬间,产生了一个想法,这个switch肯定还有我所不知道的东西,于是带着这种心情在网上各种查,终于在某一个瞬间,找到了一丝曙光。

不知道你有没有一种感觉哈,写switch特别难用,当然这是有前提的,那就是你对switch不了解。说它难用不仅仅只是说每次要加break,在if中,我们判断某个值如果等于2或者3的时候,我们可以下面这样写

var num = 3;

if(num===2||num===3){
console.log(true);
}

但如果要你在switch中实现这样的一个功能,可能会令你无从下手。

以上都是瞎说——,因为switch是可以实现这些功能的,之所以我们会觉得不能实现是因为它的这种实现方式,太容易让人误解了,并且如果你不往那方面去想,很难发现它的用处。

下面是一个用switch实现的判断num=2或=3的例子

var num = 2;

switch(num){
case 1:
console.log(1);
break;
case 2:
case 3:
console.log(2 + "或" + 3);
break;
case 4:
console.log(4);
break;
}

输出如下

这个case是一个入口,当某个值相匹配时,就会去执行相应的代码块,并且如果没有加break的话,后面的值不管是否匹配都会被执行直到遇见break将跳出switch语句,而以上的这段代码就是利用的这一点,我们在这里并没有给2的值加break;因此当值等于2的时候,还会接着往下执行,但在3中有一个break,因此执行完3就会被跳出。如果值为3则直接执行3代码块,接着跳出。

也就是说,之前我所认为的怪异,它是合理的,只是这些东西,没有被我所发现。

如果想在switch中实现判断,诸如1>2,则可以使用下面的这种方式来实现

var num = 2;

switch(true){
case num>1:
console.log("num>1");
break;
case num<1:
console.log("num<1");
break;
}

在switch中做判断的时候,需要注意一点,它用的是全等=而非,比如下面这段代码

var num = "1";

switch(num){
case 1:
console.log(1);
break;
case 2:
console.log(2);
break;
}

它并没有输出1,因为在switch中默认使用的是全等,因此它不会进行隐式转换。

如果你想实现隐式转换,可以用下面这种方式来实现。

var num = "1";

switch(true){
case num==1:
console.log(1);
break;
case num==2:
console.log(2);
break;
}

输出如下

这个true究竟是个什么...,这是你的第一反应?

之所以会有这种感觉,是因为我们对switch一直都存在着一些误解,而且这种误解很深很深,反正我从学编程以来就一直没有理解这个switch,开始是它才过于基础,导致很多人都不愿意去研究它。

为了解开这个switch之谜,我从重对它做一次讲解,用代码来讲把。

switch(x){
case n:
.....
break;
}

其中的x代表某一个值,而case中的n如果和x一模一样则会被执行,注意是一模一样,举个例子

(x = 5) 5  (n = x==5) true   因为5!==true所以不会被执行

具体代码

var num = 5;
switch(num){
case num==5:
console.log(num);
break;
}

又如

var num = 5;
switch(num){
case true:
console.log(num);
break;
}

这里所说的一模一样就是说的,num这个值和case上的值要一样,不是单方面的case为true就为true。

而我们上面给switch传true就是因为这个原因,因为true是个布尔值,所以我们才可以用判断。

其实switch并没有限制你要传什么,它才不管你传的是false还是数组,你case上的值只要和它相对应就ok,最后举个例子

switch(undefined){
case [][0]:
console.log(undefined);
break;
}

输出undefined。

虽然这篇文章是在讲switch,但我觉得它同时也说明了一个道理.........自己去悟。

走进javascript——解开switch之谜的更多相关文章

  1. Javascript 中 switch case 等于 (== )还是 恒等于(===)?

    Javascript 中 switch case 等于 (== )还是 恒等于(===)? 可以测试一下以下代码,这个 case 中是 等于(==)还是恒等于(===) <script> ...

  2. JavaScript中Switch使用

    switch 语句用于基于不同的条件来执行不同的动作.使用 switch 语句来选择要执行的多个代码块之一. switch(n) { case 1: 执行代码块 1 break; case 2: 执行 ...

  3. javascript总结10:JavaScript的Switch语句

    1 switch语句 的作用: switch 语句用于基于不同的条件来执行不同的动作. 每当满足一个变量条件,就会执行当前的case内容. break 关键字用于跳出switch代码块.会终止swit ...

  4. 雷哥带你走进Javascript

    javascript复习笔记--------------------------------------------1.概念2.面向对象思想3.作用认识4.引入方式5.执行顺序 变量 1)声明方式 x ...

  5. javascript的switch的使用注意

    如果是以下代码: <script> var t_keleyi_com = 65; switch (t_keleyi_com) { case '65': alert("字符串65. ...

  6. 走进javascript——DOM事件

    DOM事件模型 在0级DOM事件模型中,它只是简单的执行你为它绑定的事件,比如你为某个元素添加了一个onclick事件,当事件触发时,它只是去调用我们绑定的那个方法,不再做其他的操作. 在2级DOM事 ...

  7. 走进javascript——不起眼的基础,值和分号

    值 有时我很想知道javascript解析引擎是如何区分一个变量的值,比如下面这段代码. var x = 'javascript'; //javascript x = "hello" ...

  8. 初识Javascript.03 -- switch、自增、while循环、for、break、continue、数组、遍历数组、合并数组concat

    除了注意大小写,别的木啥了 Switch语句 Switch(变量){ case 1: 如果变量和1的值相同,执行该处代码 break; case 2: 如果变量和2的值相同,执行该处代码 break; ...

  9. 走进javascript——类型

    ECMAScript语言类型对应于使用ECMAScript语言的ECMAScript程序员直接操作的值.ECMAScript语言类型有以下几种Undefined,Null,Boolean,String ...

随机推荐

  1. js 设置导航固定

    <div id="nav"> .... </div> function Add_Data() { var top = $("#header-nav ...

  2. JavaScript高级程序设计-8:BOM

    1. 什么是BOM? BOM(Browser Object Mode) 是指浏览器对象模型,是用于描述这种对象与对象之间层次关系的模型,浏览器对象模型提供了独立于内容的.可以与浏览器窗口进行互动的对象 ...

  3. sql2000数据库误删除后自行恢复二次覆盖成功恢复

    sql2000数据库误删除后自行恢复二次覆盖成功恢复 [数据恢复故障描述] 今天接到一个客户电话,他的速达sql2000数据库,数据库误删除了,关键之前还没有备份过.他就想自己尝试恢复,使用网上下载的 ...

  4. dubbo框架揭秘之服务发布

    通常情况下是通过Spring配置的方式去实现服务的发布,为了方便调试,我就不采用Spring配置的方式. DemoService demo = new DemoServiceImpl(); Appli ...

  5. YII 1.0 增删改查

    查询 查询多条返回数据集合 //1.该方法是根据一个条件查询一个集合 $admin=Admin::model()->findAll($condition,$params); $admin=Adm ...

  6. iOS 之 Property List

    1. 概念 用于存储串行化对象,xml格式,存储到plist文件中. 2. 用途 存储用户设置. 3. 优点 程序运行时可动态创建和读写. 4. 使用说明 4.1. 获取plist文件 NSStrin ...

  7. 滚动视图(ScrollView)的功能与用法

    滚动视图ScrollView由FrameLayout派生而出,它就是一个用于为普通组件添加滚动条的组件.ScrollView里最多只能包含一个组件,而ScrollVew的作用就是为该组件添加垂直滚动条 ...

  8. LINQ to Sql系列一 增,删,改

    首先,我们来了解一下LINQ to sql 是什么,我想从以下几点来做说明. 1,LINQ是从.net framework 3.0开始引入的的语言特性,主要是用来对集合数据进行操作的.2,LINQ t ...

  9. 有效的GOCsharpHelper1.0(源代码开放)

    csharp编写界面,调用基于opencv的图像处理类库,是解决一类问题的优良方法.经过不懈研究,有最新进展: 一.目前情况和优点        位置在11.通过clr             架在c ...

  10. Web压力测试小工具:webbench、http_load、Siege、ab

    webbench 安装 下载地址:http://home.tiscali.cz/~cz210552/distfiles/webbench-1.5.tar.gz 或者 http://soft.vpser ...