html5中文学习网

您的位置: 首页 > 网站及特效实例 > javascript特效 » 正文

JavaScript中switch判断容易犯错的一个细节_基础知识_

[ ] 已经帮助:人解决问题

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

代码:SEmHTML5中文学习网 - HTML5先行者学习网

var n = '5';switch(n){    case 5:        alert('执行case分支');        break;    default:        alert('执行default分支');}

结果:SEmHTML5中文学习网 - HTML5先行者学习网

JS中的switchSEmHTML5中文学习网 - HTML5先行者学习网

可能很多人会误以为以上程序会走case分支,结果却走了default分支。难道它们两个不相等吗?我们使用if语句看看。SEmHTML5中文学习网 - HTML5先行者学习网

代码:SEmHTML5中文学习网 - HTML5先行者学习网

var n = '5';if(n==5){    alert('真 分支');}else{    alert('假 分支');}

结果:SEmHTML5中文学习网 - HTML5先行者学习网

JS中的switchSEmHTML5中文学习网 - HTML5先行者学习网

在if语句里可以匹配,但为何在switch语句里不能匹配呢?SEmHTML5中文学习网 - HTML5先行者学习网

这是因为在switch语句里的case使用全等模式,也就相当于if里的使用三个等号类似。我们把case的代码改写一下SEmHTML5中文学习网 - HTML5先行者学习网

代码:SEmHTML5中文学习网 - HTML5先行者学习网

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

结果:SEmHTML5中文学习网 - HTML5先行者学习网

JS中switchSEmHTML5中文学习网 - HTML5先行者学习网

改写了以后就能走case分支了,就像我们if里使用三个全等号一样SEmHTML5中文学习网 - HTML5先行者学习网

代码:SEmHTML5中文学习网 - HTML5先行者学习网

var n = '5';if(n===5){    alert('真 分支');}else{    alert('假 分支');}

结果:SEmHTML5中文学习网 - HTML5先行者学习网

JS中的switchSEmHTML5中文学习网 - HTML5先行者学习网

因为使用全等,所以字符串5不等于数字5,结果走了假分支。SEmHTML5中文学习网 - HTML5先行者学习网

由以上例子说明在 switch中使用的是全等匹配模式,特别是数字与字符串匹配的时候需要注意的一个问题SEmHTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助