[] == [] // false
[] == ![] // true
[] == false // true
![] == false // true
反直觉的弱类型转换
[] == []
结果是false,js数组是一种对象,对象对比的是地址,所以直觉上这个还算正常[] == ![]
结果是true,这个直觉上怎么都是错的,这个涉及到弱类型转换[] == false
结果是true,这个涉及到弱类型转换![] == false
结果是true,这个涉及到弱类型转换
**
二、[] == false
为True
第一步 转成[] == 0
根据 MDN Web 文档-比较操作符:developer.mozilla.org/zh-CN/docs/…
== 对比操作,如果其中一个操作数为布尔类型,那么布尔操作数如果为true,那么会转换为1,如果为false,会转换为整数0,即0。 所以false为
0
.
// [] == false 转换 false 为 0
[] == 0
第二步 转成"" == 0
根据 MDN Web 文档-比较操作符:developer.mozilla.org/zh-CN/docs/…
如果一个对象与数字或字符串相比较,JavaScript会尝试返回对象的默认值。操作符会尝试通过方法valueOf和toString将对象转换为其原始值(一个字符串或数字类型的值)。 所以
[].valueOf().toString()
为""
"" == 0
第三步 转成0 == 0
根据 MDN Web 文档-比较操作符:developer.mozilla.org/zh-CN/docs/…
当比较数字和字符串时,字符串会转换成数字值。 JavaScript 尝试将数字字面量转换为数字类型的值。
Number("")
为0
。
0 == 0
最后0==0
位True
,所以[] == false
为Ture