前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >js中 [ ]+{ } 和 { }+[ ] 的区别

js中 [ ]+{ } 和 { }+[ ] 的区别

作者头像
子舒
发布2023-08-23 14:26:49
1560
发布2023-08-23 14:26:49
举报
1668517551012
1668517551012

[ ]+{ }:一个数组加一个对象。

加法会进行隐式类型转换,规则是调用其valueOf()或toString()以取得一个非对象的值(primitive value)。

如果两个值中的任何一个是字符串,则进行字符串串接,否则进行数字加法。[ ] 和 { } 的 valueOf() 都返回对象自身,所以都会调用 toString(),最后的结果是字符串串接。

[ ].toString()返回空字符串,({ }).toString()返回 “[object Object]",最后的结果就是 “[object Object]"。

{ }+[ ]:看上去应该和上面一样。

但是{ }除了表示一个对象之外,也可以表示一个空的bock。在 [ ] + { }中,[ ]被解析为数组,因此后续的+被解析为加法运算符,而{ }就解析为对象。

但在{ } + [ ]中,{ }被解析为空的bock,随后的+被解析为正号运算符。即实际上成了:{∥empty block}+[ ],即对一个空数组执行正号运算,实际上就是把数组转型为数字。首先调用.valueOf(),返回数组自身,不是primitive value,因此继续调用 [ ].toString(),返回空字符串。空字符串转型为数字,返回0,即最后的结果。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-11-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档