var a={n:1}; var b=a; a.x=a={n:2}; console.log(a.x); console.log(b.x);

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}}

 

posted on 2018-02-01 10:24  bbqwwb  阅读(1150)  评论(0编辑  收藏  举报

导航