码迷,mamicode.com
首页 > Web开发 > 详细

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

时间:2019-09-01 01:35:54      阅读:102      评论:0      收藏:0      [点我收藏+]

标签:nbsp   结果   ==   优先   引用类型   strong   OLE   obj   false   

 []==![] 

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

标签:nbsp   结果   ==   优先   引用类型   strong   OLE   obj   false   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!