js中两个表达式运算结果的解析: []==![] 和{}==!{}

 []==![] 

1. 感叹号!的优先级最高,因此先计算![], 其结果为 false, 所以表达式被转换成: []==false.
3. 遇到Boolean类型,需要先转换成Number类型,所以表达是变成 []==0
4. 0是基础类型,[]是引用类型,所以引用类型需要转换成基础类型:[]转换的结果是 ([]).valueOf().toString(),为 “”, 所以表达式为  ""==0
5. 字符串需要转换成Number,为0. 所以表达式变成 0==0.
6.最后结果为true.
 
{}==!{}
 
1. 感叹号!的优先级最高,因此先计算!{}, 其结果为 false, 所以表达式被转换成: {}==false.
3. 遇到Boolean类型,需要先转换成Number类型,所以表达是变成 []==0
4. 0是基础类型,{}是引用类型,所以引用类型需要转换成基础类型:
    {}转换的结果是 ({}).valueOf().toString(),为 “[object Object]”, 所以表达式为  "[object Object]"==0
5. 字符串需要转换成Number,为NaN. 所以表达式变成 0==0.
6.最后结果为false.
posted @ 2019-08-31 23:51  0xMe  阅读(1630)  评论(0编辑  收藏  举报