输出以下代码的执行结果并解释为什么
var a = {n: 1};
var b = a;
a.x = a = {n: 2};
console.log (a.x);
console.log (b.x);
分析:
这种连等号是从右往左去赋值的,但是引用声明是一开始就有了。对象的赋值运算是指向赋值对象的内存空间并取值;
var a = {n: 1}; 就是声明了一个a对象并给它属性n值为1
var b = a; 声明一个b对象 a对象赋值给b ,b就指向a对象的内存空间 因此b.x=a.x
a.x = a = {n: 2}; 首先一开始就引用了声明,也就是有两个内存空间,a.x属性保存在a对象空间里,另一个内存空间保存了{n:2};然后从 右往左赋值 a = {n:2} a就指向了{n:2}这个内存空间,
注意: 这里a指向{n:2}这个空间后,原来的空间并没有消失,因为还有b指向原来的空间。
然后a.x=a ; 这里的a.x 就是b.x 因为a的内存空间指向了{n:2};原来空间里的x值仍然存在,
所以b.x={n:2},也就是b对象x属性里面保存了{n:2}这个对象
console.log (a.x);这里a.x 就不存在因为a已经指向了{n:2}这个空间,这空间里没有x属性,所以打印 undefind
console.log (b.x); b.x={n:2} 这里打印的就是 {n:2} 这个对象