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.


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM