js双等号探索(一): [] == ![]为Ture ?

[] == false; //为True
!![] == false; //为False

一、[] == false为True

第一步 转成[] == 0

根据 MDN Web 文档-比较操作符:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Operators/Comparison_Operators

js双等号探索(一): [] == ![]为Ture ?_第1张图片
0.png

如果其中一个操作数为布尔类型,那么布尔操作数如果为true,那么会转换为1,如果为false,会转换为整数0,即0。
所以![]false0.

[] == 0

第二步 转成"" == 0

根据 MDN Web 文档-比较操作符:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Operators/Comparison_Operators

js双等号探索(一): [] == ![]为Ture ?_第2张图片
image.png

如果一个对象与数字或字符串相比较,JavaScript会尝试返回对象的默认值。操作符会尝试通过方法valueOf和toString将对象转换为其原始值(一个字符串或数字类型的值)。
所以[].valueOf().toString()""

"" == 0

第三步 转成0 == 0

根据 MDN Web 文档-比较操作符:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Operators/Comparison_Operators

js双等号探索(一): [] == ![]为Ture ?_第3张图片
image.png

当比较数字和字符串时,字符串会转换成数字值。 JavaScript 尝试将数字字面量转换为数字类型的值。
Number("")0

0 == 0

最后0==0True,所以[] == falseTure

二、!![] == false为False

第一步 先运行!![]

根据 MDN Web 文档-运算符优先级:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Operators/Operator_Precedence

js双等号探索(一): [] == ![]为Ture ?_第4张图片
感叹号.png

js双等号探索(一): [] == ![]为Ture ?_第5张图片
等号.png

!的优先级为16 ,==的优先级为10!的优先级更高,所以先运行!![]

!![]

第二步 先运行!false

根据 《Javascript高级程序设计》这本书第44页中逻辑非的说明:

!.jpeg

如果操作数是一个对象,返回false

所以运行!false,为True

!false //为True

最后true == falseFalse,所以!![] == falseFalse

[] == falseTrue!![] == falseFalse

其他链接

  • https://raoenhui.github.io/js/2018/09/22/compare1/
  • https://raoenhui.github.io/js/2018/09/23/compare2/
  • https://raoenhui.github.io/js/2018/09/28/compare3/

你可能感兴趣的:(js双等号探索(一): [] == ![]为Ture ?)