js连等号运算顺序
var a = { n: 1};
var b = a;
a.x = a = {n: 2};
console.log(a.x); // 输出?
整个过程对象只有两个{n:1}和{n:2} 下面分别称为A对象和B对象 然后他们之间相互赋值和增加属性 记住 仅有两个引用地址
解答思路:
- 首先将{n:1}这个对象赋值给a变量 再将a赋值给b 这是一层浅拷贝过程 所以 a和b变量都指向同一个对象{n:1}
- 由于点运算符优先于赋值运算符所以先在{n:1}对象中创建了一个x属性 {n:1, x:(暂时无值)} 这个过程 因为运算符优先级的原因 赋值符号还未执行的时候就已经完成了
- 再然后执行 a = {n: 2} 此时a的引用地址发生了改变 从对象{n:1}指向了{n:2}
- a.x此时指向的是 {n:1, x:(暂时无值)}对象 然后将{n:2} 赋值给了a.x属性 此时A对象{n:1, x:{n:2}}
- 此时的a.x属性的父级对象a的初始引用地址是A对象 而A对象赋值给了b变量 所以你能在b.x中得到对象{n:2}
- 原对象地址因无人引用他 被垃圾回收机制回收了 对象被赋值了B对象{n:2} 所以原有的a.x为undefined