javascript中if和switch,==和===详解

作者:hebedich 时间:2024-04-22 13:23:28 

今天改插件BoxScroll的时候,因为if里面的条件判断多于两个,于是立马想着改写switch。改到一半,忽然记起来JSHint等代码质量检测工具中的一个要求,用===替换==,不用不可靠的强制转型。然后忽然猜想,改成switch是不是会降低效率啊?switch里面的实际判断是==还是===?

有了想法,赶紧举个栗子,好一口吃掉:


var a = '5';
switch (a) {
 case 5:
   console.log('==');
   break;
 case "5":
   console.log('===');
   break;
 default:
}

最后控制台显示的是===,看来可以放心的用。找了下以前的学习笔记,嗯,高三里面确实也说switch判断是全等运算符,因此不会发生类型转换。这里小结一下

1.if和switch

if 是用得最多的,没什么太多好说。值得注意的一点是:if 其实和 || 很像,如果if (conditionA){} else {} 中的conditionA为true,然后它执行完else之前的代码块后就看都不会看else里面的代码。和 || 前面为true的时候后面会被忽略一样,即便里面有再多的错误。基于这个性质,当然把可能用得最多的代码块放在前面,减少判断次数。另一方面,如果有很多的 if 判断,而且可能执行的次数分布比较均匀,那么后面的判断语句每次都要把前面的判断一个一个执行完,不利于优化。比较好的做法是将一层判断语句变成两层判断语句,如


if (a > 0 && a <= 1) {
 //do something
} else if (a > 1 && a <= 2) {

} else if (a > 2 && a <= 3) {

} else if (a > 3 && a <= 4) {

} else if (a > 4 && a <= 5) {

} else if (a > 5 && a <= 6) {

}...

变为


if (a > 0 && a <= 4) {
 if (a <= 1) {
   //do something
 } else if (a > 1 && a <= 2) {

} else if (a > 2 && a <= 3) {

} else if (a > 3 && a <= 4) {

}
} else if (a > 4 && a <= 8) {
 //
}..

虽然前面的每个判断都多加了一次,但是后面的判断就都减少了(4-1)*n次,还是满赚的。忽然觉得这种方式和嵌套循环有点像,循环次数少的放在外面有助于性能优化,如何分成两层甚至多层就要看具体情况了。

switch是 if 最亲密的战友,每次 if 忙不过来的时候就过来搭把手。switch和 if 互转估计没什么好说的,而且switch和if一样,都是顺序从上往下执行判断的,有所不同的是 if 中的else在switch里面可不管用,它有自己的小弟:break。如果没有遇到break,switch会继续往下执行,如


var a = 2;
switch (a) {
 case 1:
   console.log("1");
   //break miss
 case 2:
   console.log("2");
 case 3:
   console.log("3");
 default:
   console.log('no break');
}

最后控制台显示 2,3,no break 。其实也蛮好理解,break是提示程序跳出内部执行体到下一个case 判断,如果没有了,相当于 if(condition){A}{B},没有了else,A和B当然都要执行啦。还有两个小tip,一是switch和case中可以写任何表达式,如


switch (A + B) {
 case a * b:
   console.log("1");
   break;
 case a / b + c:
   break;
   //...
 default:
   console.log('no break');
}

实际上的比较是 (A+B)===(a*b)和(A+B)===(a/b+c)。二是switch有一种特殊的用法,如


switch (true) {
 case condition1:
   //do something
   break;
 case condition2:
   break;
   //...
 default:
   //..
   ;
}

此时switch中的每一个case都会按照顺序判断执行。至于switch(false)?并没有什么卵用。

2.==与===

一句话搞定,除了在比较之前不转换操作数之外,全等和不全等操作符与相等和不相等操作符并没有什么不同。

最经典的案例


var a = "5",
 b = 5;
a == b     //true
a === b     //false
var a = "ABC",
 b = "AB" + "C";
a === b     //true

下面的显示true的原因其实和string类型不可变是分不开的。表面看上去b只是简单的拼接一个字符串,但实际上它已经和原来的b没有关系。每一个字符串都存在内存池 * 定的地方,当b="AB"+"C"执行完的时候,字符串AB和C就已经被销毁,而b指向内存池中ABC的位置。由于在指向前在内存池中发现了字符串ABC(因为a引用着它,所以存在),所以b就和a指向同一块区域,全等判断相等。如果在b之前没有任何变量指向字符串ABC,那么内存池中没有,就会在里面划一块地方给ABC,并将b指向ABC。

附以前的总结图两张:

javascript中if和switch,==和===详解

javascript中if和switch,==和===详解

以上所述就是本文的全部内容了,希望大家能够喜欢。

标签:if,switch,==,===
0
投稿

猜你喜欢

  • 在 Windows 下搭建高效的 django 开发环境的详细教程

    2023-08-31 06:14:12
  • 用Python脚本生成Android SALT扰码的方法

    2023-05-09 22:12:25
  • 用python爬虫爬取CSDN博主信息

    2023-06-13 08:11:10
  • 一文搞懂MySQL元数据锁(MDL)

    2024-01-14 18:29:08
  • 教你如何使用php session

    2023-11-15 06:28:01
  • 利用Python计算质数与完全数的方法实例

    2022-12-30 23:35:26
  • 在Django的URLconf中进行函数导入的方法

    2023-07-10 10:46:26
  • vue组件实现可搜索下拉框扩展

    2024-05-28 15:41:57
  • python绘制玫瑰的实现代码

    2021-04-25 09:42:52
  • Python IDE PyCharm的基本快捷键和配置简介

    2021-09-18 07:08:10
  • Maui Blazor 使用摄像头实现代码

    2023-12-06 11:44:37
  • JavaScript Try...Catch 声明的 使用方法

    2024-04-18 10:52:21
  • MySQL用户账户管理和权限管理深入讲解

    2024-01-20 22:42:59
  • 学习createTrackbar的使用方法及步骤

    2021-07-29 20:02:52
  • python playwright之元素定位示例详解

    2023-06-14 01:08:41
  • JavaScript 基础问答 四

    2024-04-18 10:52:09
  • python面向对象_详谈类的继承与方法的重载

    2021-03-21 08:38:18
  • Pygame游戏开发之太空射击实战精灵的使用上篇

    2023-06-25 01:04:17
  • 一文带你学会Go select语句轻松实现高效并发

    2024-05-22 10:29:50
  • SqlServer提示“列前缀tempdb.无效: 未指定表名”问题解决方案

    2024-01-14 04:39:41
  • asp之家 网络编程 m.aspxhome.com