JavaScript/TypeScript中==和===的区别详解

作者:gentle_zhou 时间:2024-04-25 13:14:39 

在JS/TS项目里,除了能看到==操作符来判断两个变量是否相等外,我们还会看到===操作符,这两者有什么区别吗?

先上结论,

  • 对于String, number这些基础类型,==操作符会先把两边的变量进行类型强制转换成相同的类型再比较是否相等;===操作符则不会进行类型转换,而是直接进行比较。

  • 对于array, object这些高级类型,==和 ===是没有区别的,因为它们比较的是 “指针地址” 。

  • 对于基础类型和高级类型,== 和 ===是有区别的;==操作符会先把高级类型转换为基础类型之后,进行值的比较;===操作符则不会进行转换,类型不同,直接返回false

也就是说,`==`操作符只要求比较两个变量的值是否相等,`===`操作符则是要求两个变量的值和类型都要相同;类似地,`!=`操作符会去做类型强制转换,`!==`操作符则不会转换类型。

我们写个基础类型变量的代码示例一下:

66 ==  '66'; // 返回true
66 === '66' // 返回false

==操作符会把第一行里的字符串转换成数字,与66再进行比较,值相等,于是返回true;===操作符则不会做类型转换,因为左边数字,右边字符串,两者类型不同,就会返回false。

注意对于特殊值NaN(Not a Number),表示非数字,NaN和任何数(包括它自己)做相等比较,都会返回false,所以判断NaN最好用isNaN()函数;
而对于undefined和null,两者的值相比较,会返回true。

代码示例如下:

NaN == 6; // 返回false
NaN === NaN; // 返回false
null == undefined; // 返回true
null === undefined; // 返回false

最后, 由于==和!=操作符带来的类型隐式转换规则非常繁琐,还有为了避免数据类型混淆导致出现bug,还是推荐使用===操作符和!==操作符。

js在比较的时候如果是 == 会先做类型转换,再判断值得大小,如果是===类型和值必须都相等。

JavaScript/TypeScript中==和===的区别详解

JavaScript/TypeScript中==和===的区别详解

来源:https://bbs.huaweicloud.com/blogs/336334

标签:ts,==,===
0
投稿

猜你喜欢

  • Python通过RabbitMQ服务器实现交换机功能的实例教程

    2023-08-24 01:15:19
  • Python3之手动创建迭代器的实例代码

    2021-10-15 21:00:30
  • layer ui 导入文件之前传入数据的实例

    2023-08-15 11:39:17
  • python2.x实现人民币转大写人民币

    2023-06-26 10:35:53
  • Javascript操作表单之间的数据传递

    2007-10-25 12:58:00
  • javascript实现锁定网页、密码解锁效果(类似系统屏幕保护效果)

    2023-08-18 20:01:36
  • python编程通过蒙特卡洛法计算定积分详解

    2022-05-31 10:45:01
  • JS 中触发 A 标签的点击事件

    2009-01-11 17:30:00
  • Vue脚手架编写试卷页面功能

    2024-04-27 16:14:36
  • 前端图片懒加载的原理与3种实现方式举例

    2024-04-17 10:20:02
  • 教你使用Python的pygame模块实现拼图游戏

    2022-06-28 03:20:20
  • MySQL优化之使用连接(join)代替子查询

    2024-01-25 18:26:33
  • python 与c++相互调用实现

    2023-01-11 13:20:19
  • Vue前端表格导出Excel文件的图文教程

    2024-04-09 10:46:45
  • mysqldumpslow用法示例(慢查询)

    2024-01-15 22:42:03
  • 如何在CocosCreator中做一个List

    2024-04-28 09:46:04
  • Python之读取TXT文件的方法小结

    2022-10-25 16:11:34
  • 详解Python AdaBoost算法的实现

    2021-08-16 19:53:27
  • Dreamweaver使用疑难解答

    2009-09-13 18:41:00
  • Python实现的爬取百度贴吧图片功能完整示例

    2021-06-30 19:22:13
  • asp之家 网络编程 m.aspxhome.com