走进javascript——解开switch之谜
很早以前就觉得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之谜的更多相关文章
- Javascript 中 switch case 等于 (== )还是 恒等于(===)?
Javascript 中 switch case 等于 (== )还是 恒等于(===)? 可以测试一下以下代码,这个 case 中是 等于(==)还是恒等于(===) <script> ...
- JavaScript中Switch使用
switch 语句用于基于不同的条件来执行不同的动作.使用 switch 语句来选择要执行的多个代码块之一. switch(n) { case 1: 执行代码块 1 break; case 2: 执行 ...
- javascript总结10:JavaScript的Switch语句
1 switch语句 的作用: switch 语句用于基于不同的条件来执行不同的动作. 每当满足一个变量条件,就会执行当前的case内容. break 关键字用于跳出switch代码块.会终止swit ...
- 雷哥带你走进Javascript
javascript复习笔记--------------------------------------------1.概念2.面向对象思想3.作用认识4.引入方式5.执行顺序 变量 1)声明方式 x ...
- javascript的switch的使用注意
如果是以下代码: <script> var t_keleyi_com = 65; switch (t_keleyi_com) { case '65': alert("字符串65. ...
- 走进javascript——DOM事件
DOM事件模型 在0级DOM事件模型中,它只是简单的执行你为它绑定的事件,比如你为某个元素添加了一个onclick事件,当事件触发时,它只是去调用我们绑定的那个方法,不再做其他的操作. 在2级DOM事 ...
- 走进javascript——不起眼的基础,值和分号
值 有时我很想知道javascript解析引擎是如何区分一个变量的值,比如下面这段代码. var x = 'javascript'; //javascript x = "hello" ...
- 初识Javascript.03 -- switch、自增、while循环、for、break、continue、数组、遍历数组、合并数组concat
除了注意大小写,别的木啥了 Switch语句 Switch(变量){ case 1: 如果变量和1的值相同,执行该处代码 break; case 2: 如果变量和2的值相同,执行该处代码 break; ...
- 走进javascript——类型
ECMAScript语言类型对应于使用ECMAScript语言的ECMAScript程序员直接操作的值.ECMAScript语言类型有以下几种Undefined,Null,Boolean,String ...
随机推荐
- 关于学习方法的借鉴和有关C语言学习的调查
专长的高超技能获取的成功经验 在游戏方面,我相对于大多数人来说可能更为出色.首先是我投入了大量的时间进行游戏:其次,我几乎每天都会看一会教学视频来模仿:最后应该还是跟个人的天赋有点关系. 如果把这个类 ...
- C语言-基础
程序是为了让计算机完成某项任务而编写的逐条执行的指令序列. C语言的特点是:结构化,语言简洁,功能强大,移植性好. 因为移植性好,所以大多数单片机如51.stm32,msp430,等众多嵌入式微处理器 ...
- 安卓弹出对话框——Alertdialog(一)
首先看各种样式的对话框: 我们看到,Dialog有很多的子类实现,所以我们要定义一个对话框,使用其子类来实例化一个即可,而不要直接使用Dialog这个父类来构造. 二.AlertDialog 今天我们 ...
- bzoj1562[NOI2009]变换序列——2016——3——12
任意门:http://www.lydsy.com/JudgeOnline/problem.php?id=1562 题目: 对于0,1,…,N-1的N个整数,给定一个距离序列D0,D1,…,DN-1,定 ...
- iOS 之 文件缓存
对于信息量不是太大的数据,可以使用文件缓存来处理.文件缓存可以缓存字典和数组. 步骤一:创建路径 路径要一级一级往下创建,基本不用考虑创建失败的情况.但是如果创建失败了要怎么做呢?按道理应该提示出来. ...
- 最多两次股票交易-Best Time to Buy and Sell Stock III
Say you have an array for which the ith element is the price of a given stock on day i. Design an al ...
- NodeMCU之旅(一):构建、刷入固件,上传代码
扬帆起航 本系列文章将试图实现,使用Web页面远程点亮led.具体包括: 在NodeMCU上搭建HTTP服务器,使其可以通过Web页面配置要接入的网络. 在配置页面可以显示附近中英网络名与信号强度. ...
- Ionic在线打包IOS平台应用
参见:http://docs.ionic.io/services/profiles/#ios-app-certificate--provisioning-profile Ionic云编译,需要注册.地 ...
- HDU5692(线段树+dfs序)
Snacks Time Limit:5000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Submit Statu ...
- SQLite:自学笔记(1)——快速入门
SQLite的安装和入门 了解 啥是SQLite? SQLite是一种轻巧迷你的关系型数据库管理系统.它的特点如下: 不需要一个单独的服务器进程或操作的系统(无服务器的). SQLite 不需要配置, ...