首页 > Web开发 > 详细

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

时间:2019-09-01 00:25:05      阅读:82      评论:0      收藏:0      [点我收藏+]

 []==![] 

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中两个表达式运算结果的解析: []==![] 和{}==!{}

原文:https://www.cnblogs.com/0xMe/p/11441104.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!