JS

你知道下面这行代码是在干什么?

const street = data && data.user && data.user.address && data.user.address.street;
1

==与===

[]==[]  ->false
[]!==[]  ->true
[]==![]  ->true

{}=={}  ->false
{}!=={}  ->true
{}==!{}  ->false
1
2
3
4
5
6
7

相等和不相等 ——先转换再比较 (==)

全等和不全等 ——仅比较而不转换 (===)---不涉及类型转换,不讨论

非基础类型比较的是引用地址,所以即使值相等,也为false

  1. 如果有一个操作数是布尔值,则在比较相等性之前先将其转换为数值——false转换为0,而true转换为1;
  2. 如果一个操作数是字符串,另一个操作数是数值,在比较相等性之前先将字符串转换为数值
  3. 如果一个操作数是对象,另一个操作数不是,则调用对象的valueOf()方法,用得到的基本类型值按照前面的规则进行比较
  4. null 和undefined 是相等的
  5. 要比较相等性之前,不能将null 和 undefined 转换成其他任何值
  6. 如果有一个操作数是NaN,则相等操作符返回 false ,而不相等操作符返回 true。重要提示:即使两个操作数都是NaN,相等操作符也返回 false了;因为按照规则, NaN 不等于 NaN
  7. 如果两个操作数都是对象,则比较它们是不是同一个对象,如果两个操作数都指向同一个对象,则相等操作符返回 true;否则, 返回false

※ {}.toString() -> NaN(返回的是NaN)