==和===区别

1 等于操作符

等于操作符⽤两个等于号( == )表⽰,如果操作数相等,则会返回 true

前⾯⽂章,我们提到在JavaScript中存在隐式转换。等于操作符(==)在⽐较中会先进⾏类型转换,再确定操作数是否相等

遵循以下规则:

  • 如果任⼀操作数是布尔值,则将其转换为数值再⽐较是否相等
  • 如果⼀个操作数是字符串,另⼀个操作数是数值,则尝试将字符串转换为数值,再⽐较是否相等
  • 如果⼀个操作数是对象,另⼀个操作数不是,则调⽤对象的 valueOf()⽅法取得其原始值,再根据前⾯的规则进⾏⽐较

null和undefined相等

如果有任⼀操作数是 NaN ,则相等操作符返回 false

如果两个操作数都是对象,则⽐较它们是不是同⼀个对象。如果两个操作数都指向同⼀个对象,则相等操作符返回true

下⾯进⼀步做个⼩结:

  • 两个都为简单类型,字符串和布尔值都会转换成数值,再⽐较
  • 简单类型与引⽤类型⽐较,对象转化成其原始类型的值,再⽐较
  • 两个都为引⽤类型,则⽐较它们是否指向同⼀个对象
  • null 和 undefined 相等
  • 存在 NaN 则返回 false

2 全等操作符

全等操作符由 3 个等于号( === )表⽰,只有两个操作数在不转换的前提下相等才返回 true。即类型相同,值也需相同

undefined 和 null 与⾃⾝严格相等

3 区别

相等操作符(==)会做类型转换,再进⾏值的⽐较,全等运算符不会做类型转换

null 和 undefined ⽐较,相等操作符(==)为true,全等为false

4 ⼩结

相等运算符隐藏的类型转换,会带来⼀些违反直觉的结果

但在⽐较null的情况的时候,我们⼀般使⽤相等操作符==

等同于下⾯写法

使⽤相等操作符(==)的写法明显更加简洁了

所以,除了在⽐较对象属性为null或者undefined的情况下,我们可以使⽤相等操作符(),其他情况⼀律使⽤全等操作符