码迷,mamicode.com
首页 > Web开发 > 详细

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

时间:2015-05-18 09:07:25      阅读:298      评论:0      收藏:0      [点我收藏+]

标签:原型对象   实例对象   构造函数   prototype   constructor   

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的原型对象。

 

 

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

标签:原型对象   实例对象   构造函数   prototype   constructor   

原文地址:http://blog.csdn.net/u014205965/article/details/45798861

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!