JS对象引用

如果不同的变量名指向同一个对象,那么它们都是这个对象的引用,也就是说指向同一个内存地址。修改其中一个变量,会影响到其他所有变量。

1
2
3
4
5
6
7
8
var o1 = {};
var o2 = o1;

o1.a = 1;
o2.a // 1

o2.b = 2;
o1.b // 2
上面代码中,o1和o2指向同一个对象,因此为其中任何一个变量添加属性,另一个变量都可以读写该属性。

如果取消某一个变量对于原对象的引用,不会改变已经引用过的另一个变量。

1
2
3
4
5
6
7
var o1 = {};
var o2 = o1;

o1 = 1;
console.log(o2); // {}
console.log(o1); // 1
console.log(typeof o1); // number

上面代码中,o1和o2指向同一个对象,然后o1的值变为1,这时不会对o2产生影响,o2还是指向原来的那个对象。

注意:这种引用只局限于object,如果两个变量指向同一个原始类型的值,则变量这时都是值的拷贝。

1
2
3
4
5
var x = 1;
var y = x;

x = 2;
y // 1

上面代码中,当x的值变化后,y值不变,这就表示y和x并不是指向同一个内存地址。

ref: 阮一峰