js中两个表达式运算结果的解析: []==![] 和{}==!{}
Posted 0xme
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js中两个表达式运算结果的解析: []==![] 和{}==!{}相关的知识,希望对你有一定的参考价值。
[]==![]
1. 感叹号!的优先级最高,因此先计算![], 其结果为 false, 所以表达式被转换成: []==false.
3. 遇到Boolean类型,需要先转换成Number类型,所以表达是变成 []==0
4. 0是基础类型,[]是引用类型,所以引用类型需要转换成基础类型:[]转换的结果是 ([]).valueOf().toString(),为 “”, 所以表达式为 ""==0
5. 字符串需要转换成Number,为0.
6.结果是0==0.
7.最后结果为true.
==!
1. 感叹号!的优先级最高,因此先计算!, 其结果为 false, 所以表达式被转换成: ==false.
3. 遇到Boolean类型,需要先转换成Number类型,所以表达是变成 []==0
4. 0是基础类型,是引用类型,所以引用类型需要转换成基础类型:
转换的结果是 ().valueOf().toString(),为 “[object Object]”, 所以表达式为 "[object Object]"==0
5. 字符串需要转换成Number,为NaN.
6.结果是NaN==0.
7.最后结果为false.
以上是关于js中两个表达式运算结果的解析: []==![] 和{}==!{}的主要内容,如果未能解决你的问题,请参考以下文章