JS面向对象-原型对象,实例对象,构造函数的关系

JS中每创建一个函数,该函数就会自动拥有一个prototype属性,为什么那?? 

因为最根上的object拥有一个prototype属性,而js中所有的对象又都继承自object,所以js中所有的对象都拥有一个prototype属性,而在js中函数也是对象,所以js中每个函数也都有一个prototype属性。

例如:function Person(){...} 和function Dog(){...}

技术分享


而每一个prototype属性又会获得一个constructor属性

技术分享

 

该constructor属性有一个隐含的指针,指向了prototype属性所在的函数。

技术分享

 

这里就说明了,当用alert函数弹出 Person.prototype.constructor 的时候,弹出的结果是

function Person{....}

当通过new Person() 创建一个对象实例后,该实例包含一个隐含的指针,指向了Person.prototype 

技术分享

 

 

结合之前的例子,通过图示说明一下 构造函数,实例对象,原型对象之间的关系

技术分享

 

Person 的每个实例都包含一个隐形指针,指向Person.prototype,换句话说,它们与构造函数没有直接关系。

 

可以用isPrototypeof( ) 来判定一个“实例”是否指向某个“原型对象”;也可以理解为某个实例是否源于某个原型对象。

alert(Person.prototype.isPrototypeof(p1 )) 返回true,说明p1指向Person.prototype,

Person.prototype 是实例p1的原型对象。

 

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。