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
2
3
4
5
6
7
相等和不相等 ——先转换再比较 (==)
全等和不全等 ——仅比较而不转换 (===)---不涉及类型转换,不讨论
非基础类型比较的是引用地址,所以即使值相等,也为false
- 如果有一个操作数是布尔值,则在比较相等性之前先将其转换为数值——false转换为0,而true转换为1;
- 如果一个操作数是字符串,另一个操作数是数值,在比较相等性之前先将字符串转换为数值
- 如果一个操作数是对象,另一个操作数不是,则调用对象的valueOf()方法,用得到的基本类型值按照前面的规则进行比较
- null 和undefined 是相等的
- 要比较相等性之前,不能将null 和 undefined 转换成其他任何值
- 如果有一个操作数是NaN,则相等操作符返回 false ,而不相等操作符返回 true。重要提示:即使两个操作数都是NaN,相等操作符也返回 false了;因为按照规则, NaN 不等于 NaN
- 如果两个操作数都是对象,则比较它们是不是同一个对象,如果两个操作数都指向同一个对象,则相等操作符返回 true;否则, 返回false
※ {}.toString() -> NaN(返回的是NaN)
CSS →