var a = {n:1};//创建对象{n:1},赋值给avar b = a;//b引用a的对象,实际上此时内存只有一个对象。变量a,b同时指向这个对象a.x = a = {n:2};//此时将这个对象的键值x赋值,赋值内容是运算表达式a={n:2}的运算结果{n:2}//a={n:2}这个运算表达式又创建了一个对象{n:2},同时让a指向这个对象//此时内存中有两个对象 a指向于新的对象{n:2},b指向于原对象{n:1,x:{n:2}}console.log(a.x);// -->undefinedconsole.log(b.x);// -->{n:2}
以上是一种解析 另一种解析是:
首先 . 运算符优先级高于= 所以先给{n:1}对象创建了x属性,对象变成{n:1,x:undefined}(当前a和b都是指向此内存对象),
然后连等从右往左执行,先把a指向改成{n:2},然后把最初的内存对象的x属性指向改成{n:2}(因为.运算符已执行,所以此时a.x是指{n:1,x:undefined}的x属性),内存对象变成{n:1,x:{n:2}}
此时只有b还是指向这个内存对象 所以:
a.x -->undefined
b -->{n:1,x:{n:2}}