var a = {n:1};//创建对象{n:1},赋值给a
var 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);// -->undefined
console.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}}
引用:
转载:https://www.cnblogs.com/bbqwwb/p/8397712.html
更详细的解析:https://blog.csdn.net/mx18519142864/article/details/83111207