JavaScript中三个等号和两个等号的区别(== 和 ===)浅析

  • 概念

    (1) "=="叫做相等运算符,"==="叫做严格运算符。
    (2) ==,equality -> 等同 的意思, 两边值类型不同的时候,要先进行类型转换为同一类型后,再比较值是否相等。
    ===,identity -> 恒等 的意思,不做类型转换,类型不同的结果一定不等。
    (3) "=="表示只要值相等即可为真,而"==="则要求不仅值相等,而且也要求类型相同。

    对于明确数据类型的用===更为可靠,JavaScript是一门弱类型语言,表达式运算赋值等操作都会导致类型转换。而一些隐式转换会带来一些意想不到的后果

  • 规则

1、===:称为等同符,当两边值的类型相同时,直接比较值,若类型不相同,直接返回false;

2、==:称为等值符,当等号两边的类型相同时,直接比较值是否相等,若不相同,则先转化为类型相同的值,再进行比较;

    类型转换规则:

       1)如果等号两边是boolean、string、number三者中任意两者进行比较时,优先转换为数字进行比较。

       2)如果等号两边出现了null或undefined,null和undefined除了和自己相等,就彼此相等

注意:NaN==NaN //返回false,NaN和所有值包括自己都不相等。

  • 示例

1.1 字符串 == 数字 ;字符串转换成数字

console.log(1 == ‘1’); // true

1.2 布尔值 == 数字; 布尔值转成数字

console.log(1 == true); // true;

1.3 布尔值 == 字符串; 布尔值转数字,字符串也转成数字,然后进行比较;

console.log(false == ‘0’); // true

1.4 null == undefined // true, null 和undefined和其他数据类型比较都是false
1.5 对象 == 对象; 比较的是空间地址,地址相同返回true

console.log({} == {}); // false

1.6 对象 == 字符串; 对象转成字符串,然后和字符串比较

console.log({} == ‘[object Object]’); // true

1.7 对象 == 布尔值;对象先转成字符串,再转数字,布尔值也转成数字,在比较这两个数字

console.log({} == true); // false
console.log([] == false); // true

1.8 对象 == 数字;对象先转成字符串,然后再转成数字

console.log({} == 1); // false
console.log([] == 0); // true

特殊:NaN和NaN 永远不相等

console.log(NaN == NaN); // NaN和NaN 永远不相等

 

posted @ 2021-07-07 18:57  tolin  阅读(459)  评论(0编辑  收藏  举报