本文分享自华为云社区《JavaScript/TypeScript里 == 和 === 的区别》,作者: gentle_zhou。
在JS/TS项目里,除了能看到==操作符来判断两个变量是否相等外,我们还会看到===操作符,这两者有什么区别吗?
先上结论,
也就是说,==
操作符只要求比较两个变量的值是否相等,===
操作符则是要求两个变量的值和类型都要相同;类似地,!=
操作符会去做类型强制转换,!==
操作符则不会转换类型。
我们写个基础类型变量的代码示例一下:
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,还是推荐使用===操作符和!==操作符。
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://huaweicloud.blog.csdn.net/article/details/123480411
内容来源于网络,如有侵权,请联系作者删除!