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中两个表达式运算结果的解析: []==![] 和{}==!{}的主要内容,如果未能解决你的问题,请参考以下文章

QT之计算器解析算法下

四则运算的解析

逗号表达式的分析

Python全栈day18(三元运算,列表解析,生成器表达式)

江哥带你玩转C语言 | 06-C语言运算符

表达式计算-----------eval()运算符