84669 人學習
152542 人學習
20005 人學習
5487 人學習
7821 人學習
359900 人學習
3350 人學習
180660 人學習
48569 人學習
18603 人學習
40936 人學習
1549 人學習
1183 人學習
32909 人學習
js中存在内部类型转换,在进行此类运算时先调用对象的valueOf,如果得到的不是基本的值类型,再调用对象的toString。
按以上原则,
1 + {} = "1[object Object]" {} + 1 = "[object Object]1"
然而实际结果是
{} + 1 = 1
学习是最好的投资!
补充一点楼上的:并不仅是在console里{}被解析为代码块,而是在JavaScript的解析器中{}被解析为代码块,如果外面加上(),({} + 1)/( 1 + {})中括号里面的内容则被解析成表达式,表达式中没有语句块,所以+作为二元运算符,{}作为运算符的操作数解析而不是空代码块。
JavaScript
({} + 1)/( 1 + {})
{} + 1,根据解析的顺序,{}作为空代码块被忽略,实际上就是+11 + {},+被解析成二元运算符,然后解析到{},就相等于一个primitiveValue + objectValue
{} + 1
+1
1 + {}
{} + {} -> NaN,第一个{}被解析成空代码块,+解析成一元运算符,相当于+{},强制转成数字。({} + {})->"[object Object][object Object]",()中解析成表达式,+被解析成二元运算符,{}作为操作数,根据转换类型规则,调用toString()方法。
{} + {} -> NaN
({} + {})->"[object Object][object Object]"
更新下关于{}+{}的问题在Firefox、IE中结果为NaN,在Chrome、Safari、Node.js(V8引擎)中结果为"[object Object][object Object]",至于为啥,我也不知道o(╯□╰)o上个参考链接:http://www.2ality.com/2012/01...
{}+{}
NaN
"[object Object][object Object]"
因为在console里{}被认为是一个code block,而不是Object。
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"
补充一点楼上的:
并不仅是在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...
因为在console里{}被认为是一个
code block
,而不是Object
。