文章目录
  1. 1. 基本原则
  2. 2. ===
  3. 3. ==
    1. 3.1. 如果两个值类型相同,进行 === 比较。
    2. 3.2. 如果两个值类型不同,他们可能相等。根据下面规则进行类型转换再比较
  4. 4. 分类对比
    1. 4.1. 对于string,number等基础类型,==和===是有区别的
    2. 4.2. 对于Array,Object等高级类型,==和===是没有区别的
    3. 4.3. 基础类型与高级类型,==和===是有区别的

在JS中我们可能会经常看到代码中使用===或者!==用于比较,这两个符号和以前java中使用的==和!=有什么区别和联系呢?今天我们就简单介绍一下。

基本原则

== equality 等同,=== identity 恒等。

==, 两边值类型不同的时候,要先进行类型转换,再比较。

===,不做类型转换,类型不同的一定不等。

===

  1. 如果类型不同,就[不相等]
  2. 如果两个都是数值,并且是同一个值,那么[相等];(!例外)的是,如果其中至少一个是NaN,那么[不相等]。(判断一个值是否是NaN,只能用isNaN()来判断)
  3. 如果两个都是字符串,每个位置的字符都一样,那么[相等];否则[不相等]。
  4. 如果两个值都是true,或者都是false,那么[相等]。
  5. 如果两个值都引用同一个对象或函数,那么[相等];否则[不相等]。
  6. 如果两个值都是null,或者都是undefined,那么[相等]。

==

如果两个值类型相同,进行 === 比较。

如果两个值类型不同,他们可能相等。根据下面规则进行类型转换再比较

  1. 如果一个是null、一个是undefined,那么[相等]
  2. 如果一个是字符串,一个是数值,把字符串转换成数值再进行比较。
  3. 如果任一值是 true,把它转换成 1 再比较;如果任一值是 false,把它转换成 0 再比较。
  4. 如果一个是对象,另一个是数值或字符串,把对象转换成基础类型的值再比较。对象转换成基础类型,利用它的toString或者valueOf方法。
  5. 任何其他组合,都[不相等]

如果把一个变量用在逻辑运算中,那么变量在无初始值或者其值为 0、-0、null、””、false、undefined 或者 NaN时,它的值为 false。否则,其值为 true。

分类对比

对于string,number等基础类型,==和===是有区别的

  1. 不同类型间比较,==之比较“转化成同一类型后的值”看“值”是否相等,===如果类型不同,其结果就是不等
  2. 同类型比较,直接进行“值”比较,两者结果一样

对于Array,Object等高级类型,==和===是没有区别的

进行“指针地址”比较

基础类型与高级类型,==和===是有区别的

  1. 对于==,将高级转化为基础类型,进行“值”比较
  2. 因为类型不同,===结果为false
文章目录
  1. 1. 基本原则
  2. 2. ===
  3. 3. ==
    1. 3.1. 如果两个值类型相同,进行 === 比较。
    2. 3.2. 如果两个值类型不同,他们可能相等。根据下面规则进行类型转换再比较
  4. 4. 分类对比
    1. 4.1. 对于string,number等基础类型,==和===是有区别的
    2. 4.2. 对于Array,Object等高级类型,==和===是没有区别的
    3. 4.3. 基础类型与高级类型,==和===是有区别的