1. [] == [] // false
  2. [] == ![] // true
  3. [] == false // true
  4. ![] == 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。 所以false0.

  1. // [] == false 转换 false 为 0
  2. [] == 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==0True,所以[] == falseTure