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

更新日期: 2019-08-01阅读量: 857标签: 表达式

 []==![] 

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.
站长推荐

1.云服务推荐: 国内主流云服务商/虚拟空间,各类云产品的最新活动,优惠券领取。领取地址:阿里云腾讯云硅云

链接: https://www.fly63.com/article/detial/5078

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!