关于prototype属性的理解

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于prototype属性的理解相关的知识,希望对你有一定的参考价值。

      众所周知,prototype是一个属性对象,只要创建一个新函数,就会根据特定的规则为该函数创建一个prototype属性,这个属性指向函数的原型对象。在默认情况下,所有原型对象都会自动获得一个constructor(构造函数)属性,这个属性包含一个指向prototype属性所在函数的指针。

      需要注意的是,prototype是一个对象,他具体的内部结构是这样的:

     

//创建一个原型对象
function Foo(){};
console.log(typeof Foo.prototype);  // ‘object‘
Foo.prototype.x=1;
Foo.prototype.show=function(){
alert(this.name);
}
//则其内部结构 Foo.prototype { constructor:Foo, _proto_:Object.prototype,
show:function()... x:
1; }

   根据其内部结构我们再来看最上面的一句话,每个由原型对象创建的对象实例,都会有一个prototype属性,其指向原型对象的prototype属性。原型对象都会自动获得一个constructor属性,这个属性包含一个指向prototype属性所在函数的指针,即在这里的 Foo.prototype.constructor指向Foo.

   接下来我们在定义这样一段代码

var foo=new Foo();
foo.name="小明";
//通过上面的说明,我们可以知道foo.prototype的内部结构
foo.prototype
{
       constructor:foo,
       _proto_:Foo.prototype,

}
foo.show(); //小明

 这里,之所以foo对象实例能够调用show()方法的原因就是:js引擎在foo对象中没有找到show()方法,便通过其prototype属性对象中的_proto_属性向上找到Foo.prototype属性里面的show()方法,来完成调用。

以上是关于关于prototype属性的理解的主要内容,如果未能解决你的问题,请参考以下文章

关于原型原型链和原型继承的理解

关于js中原型链的理解

总结:关于原型需要知道的几个问题

js的Prototype属性

简单理解js的prototype属性

关于CSS的个人理解