js中存在内部类型转换,在进行此类运算时先调用对象的valueOf,如果得到的不是基本的值类型,再调用对象的toString。
按以上原则,
1 + {} = "1[object Object]"
{} + 1 = "[object Object]1"
然而实际结果是
{} + 1 = 1
js中存在内部类型转换,在进行此类运算时先调用对象的valueOf,如果得到的不是基本的值类型,再调用对象的toString。
按以上原则,
1 + {} = "1[object Object]"
{} + 1 = "[object Object]1"
然而实际结果是
{} + 1 = 1
因为在console里{}被认为是一个code block
,而不是Object
。
var a = {};
1 + a // "1[object Object]"
a + 1 // "[object Object]1"
(1 + {}) // "1[object Object]"
({} + 1) // "[object Object]1"
console.log(1 + {}) // "1[object Object]"
console.log({} + 1) // "[object Object]1"
13 回答12.8k 阅读
7 回答1.9k 阅读
3 回答1.1k 阅读✓ 已解决
2 回答1.2k 阅读✓ 已解决
6 回答873 阅读✓ 已解决
6 回答1k 阅读
2 回答1.3k 阅读✓ 已解决
补充一点楼上的:
并不仅是在console里{}被解析为代码块,而是在
JavaScript
的解析器中{}被解析为代码块,如果外面加上(),({} + 1)/( 1 + {})
中括号里面的内容则被解析成表达式,表达式中没有语句块,所以+作为二元运算符,{}作为运算符的操作数解析而不是空代码块。{} + 1
,根据解析的顺序,{}作为空代码块被忽略,实际上就是+1
1 + {}
,+被解析成二元运算符,然后解析到{},就相等于一个primitiveValue + objectValue{} + {} -> NaN
,第一个{}被解析成空代码块,+解析成一元运算符,相当于+{},强制转成数字。({} + {})->"[object Object][object Object]"
,()中解析成表达式,+被解析成二元运算符,{}作为操作数,根据转换类型规则,调用toString()方法。更新下关于
{}+{}
的问题在Firefox、IE中结果为
NaN
,在Chrome、Safari、Node.js(V8引擎)中结果为
"[object Object][object Object]"
,至于为啥,我也不知道o(╯□╰)o上个参考链接:http://www.2ality.com/2012/01...