美文网首页
JavaScript 彻底读懂和使用 == 和 ===

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

作者: BluesCurry | 来源:发表于2018-03-06 23:04 被阅读0次

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

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

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

    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中什么时候使用==是正确的?

    相关文章

      网友评论

          本文标题:JavaScript 彻底读懂和使用 == 和 ===

          本文链接:https://www.haomeiwen.com/subject/rbzrfftx.html