①.n个引用变量指向同一个对象,通过其中一个变量修改对象内部数据,其它所有变量看到的是修改之后的数据。
var obj1 = {name:'tom'};
var obj2 = obj1;//将obj1的内容保存给obj2
obj1.name = 'jack';
obj2.age = 18;
console.log(obj2.name);//jack
console.log(obj1.age);//18
function fn(obj) {
obj.name = 'bob'
}
fn(obj1);
console.log(obj2.name);//bob
②.多个个引用变量指向同一个对象,让其中一个引用变量指向另一个对象,其他的引用变量依然指向前一个对象。
var a = {age:12};
var b = a;
a = {name:'bob',age:13};
console.log(b.age,a.name,a.age);//12 bob 13 此时b指向的是a之前的内存空间中的对象,a指向的是新的对象,a不要之前的了。也就是说a和b不关联了。
b.age = 14;
console.log(b.age,a.name,a.age);//14 bob 13
function fn2(obj) {
obj = {age:15}
}
fn2(a);
console.log(a.age);//13
//执行过程为,先把a的内容给obj,obj和a指的是同一个对象,然后obj自己开辟了一块内存去指向了新的对象,a和obj就没有关联了,所以a.age还是13。