test.js
var a = {name: 1};
var b = a;
console.log(a);
console.log(b);
====================
b.name = 2;
console.log(a);
console.log(b);
====================
var b = {name: 3};
console.log(a);
console.log(b);
====================
运行 test.js 结果为:
{ name: 1 }
{ name: 1 }
=======================
{ name: 2 }
{ name: 2 }
=======================
{ name: 2 }
{ name: 3 }
解释:a 是一个对象,b 是对 a 的引用,即 a 和 b 指向同一块内存,所以前两个输出一样。当对 b 作修改时,即 a 和 b 指向同一块内存地址的内容发生了改变,所以 a 也会体现出来,所以第三四个输出一样。当 b 被覆盖时,b 指向了一块新的内存,a 还是指向原来的内存,所以最后两个输出不一样。
本文通过一个简单的JavaScript示例,深入浅出地解析了对象及其引用的工作原理。演示了当两个变量指向同一个对象时,对其中一个变量所引用的对象进行修改如何影响另一个变量。同时,展示了重新赋值一个变量时,原始对象不受新赋值的影响。

被折叠的 条评论
为什么被折叠?



