js中的对象的引用

JavaScript012

js中的对象的引用,第1张

是不一样的,可以这么说,同一个构造函数,无论在哪儿实例化对象,在内存中的地址是不一样的,没实例化一次,就会对应新的内存地址。你可以在构造函数中,声明一个随机数变量:如var suiji = Math.random() 然后实例化对象,输出这个变量,那肯定不是一样的,说明不是一块内存地址。

第一个函数的输出应该是 张三 李四,第二个函数的输出应该是两个李四

第一个函数很容易理解:构造函数生成了一个共有属性name,然后new了2个新函数,分别定义了自己的name,输出当然是自己的name值;

第二个函数设计到一个引用。

你先看下这个例子:

var a=1

var b=a

a=2

console.log(b) //1

//当a的引用是在本地的时候b等于a,a改变自己的value,b不发生改变。

var a={name:999}

var b=a

a.name = 1000

console.log(b.name) //1000

//当a的引用是一个对象时,引用并不是在本地,其实a指向的是一个内存地址,

//b=a表示,b也和a一样指向了这个内存地址。

//a.name 当a改变所指向的内存地址的值时,同时也影响到了b的值,所以b输出1000 而不是输出999

回头看你的第二个函数

构造函数Fun拥有一个共有属性info,info中有2个键值队,当你new了新函数后,用a.info其实是改变了info的引用对象,

同样b.info第二次改变了info的引用对象,因为a,b指向同一个内存地址 所以每次改变都会导致2个变量的值同时发生变更,于是输出了2个李四