JavaScript 彻底读懂和使用 == 和 ===

首先我们要知道 ===== 到底都是什么概念,区别是什么,才可以在不用的场景中使用这两个运算符。

=== 叫做严格运算符, == 叫做相等运算符。

严格运算符的运算规则如下:

  1. 如果两个值的类型不同,直接返回 false
  2. 同一类型的原始类型的值(数值、字符串、布尔值)比较时,值相同就返回 true,值不同就返回 false
  3. 两个复合了类型(对象、数组、函数)的数据比较时,不是比较它们的值是否相等,而是比较它们是否指向同一个对象。
  4. undefinednull 与自身严格相等。

下面举几个例子:

'111' === 111 // false
111 === 111 // true
111 === 222 // false
{a:'1'} === {a:'1'} // false
var a = {value:'1'};
var b = {value:'1'};
a === b; // false
a === a; // true
var c = a;
c === a; // true
null === null // true
undefined === undefined // true

相等运算符在比较相同类型的数据时,与严格相等运算符完全一样。

在比较不同类型的数据时,相等运算符会先将数据进行类型转换,然后再用严格相等运算符比较。

类型转换规则如下:

  1. 原始类型的数据会转换成数值类型再进行比较。字符串和布尔值都会转换成数值。
  2. 对象(这里指广义的对象,包括数值和函数)与原始类型值比较时,对象转化成原始类型的值,再进行比较。
  3. undefinednull 与其他类型的值比较时,结果都为 false,它们相互比较时结果为 true

通过上面类型转换规则的介绍我们可以看出,相等运算符隐藏的类型转换,会带来一个违反直觉的结果。

下面举几个例子:

'' == '0' // false
0 == '' // true
0 == '0' // true

false == 'false' // false
false == '0' // true

false == undefined // false
false == null // false
null == undefined // true

' \t\r\n ' == 0 // true

甚至还会改变比较的数据的值!请看代码:

var x = 1;
var obj = {
  valueOf: function() {
    x = 2;
    return 0;
  }
}
console.log(obj == 0, x); // true, 2
// 根据类型转换规则的第二点可知对象与原始类型的值比较时,对象会转化成原始类型的值,再进行比较。在对象转化成原始类型的过程中会调用 obj.valueOf 这个方法所以全局变量 x 会赋值为 2

或者产生异常

var x = 1;
var obj = {
  valueOf: function() {
    return {}
  },
  toString: function() {
    return {}
  }
}
console.log(obj == 0); // Error: Cannot convert object to primitive value
// 中文解释为 "不能将对象转换为原始值",详见 http://blog.csdn.net/wopelo/article/details/61913796

由此可见,使用 == 在很多情况下是不安全的,并且可能会造成一些错误。这就是为什么建议尽量不要使用相等运算符的原因。

那到底什么时候可以使用 == 相等运算符呢?

答案:是只有在检测 null/undefined 的时候可以使用 x == null,因为我们通常不区分 nullundefined ,即将 x == null 作为 x === null || x === undefined 的缩写。其他时候会建议使用严格运算符。

如果非要问还有没有其他情况可以使用 == 相等运算符,这里有一篇文章进行了详细的介绍,可以参考:
在JavaScript中什么时候使用==是正确的?

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    悟名先生阅读 9,740评论 0 13
  • 标签: 我的笔记 ---学习资料:http://javascript.ruanyifeng.com/ 1. 导论 ...
    暗夜的怒吼阅读 4,298评论 0 1
  • 运算符是处理数据的基本方法,用来从现有的值得到新的值。JavaScript 提供了多种运算符,本章逐一介绍这些运算...
    许先生__阅读 3,826评论 0 3
  • 吃一只芒果,果核占了一半。 于是写: 天气被秋雨赶着奔向了冬天,又想起一件趣事,于是写: 当时的心情是很绝望的。笑...
    苏白杞阅读 2,241评论 15 12
  • 天眼即人上丹田处,最形象的表现就是二郎神的第三只眼,开天眼就是通过修行打开这个第三只眼。在中国长大的人,一定都听说...
    linhuizhang阅读 4,705评论 0 0

友情链接更多精彩内容