深入理解javascript原型和闭包——prototype原型

Posted smy225

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了深入理解javascript原型和闭包——prototype原型相关的知识,希望对你有一定的参考价值。

上文中提到对象是函数创建得,而函数也是一种对象。对象就是属性的集合,没有方法。

每个函数都有一个属性——prototype。

这个prototype的属性值是一个对象(属性的集合),默认有一个constructor属性,指向这个函数本身。

上图中,superType是一个函数,这个函数有个prototype属性,该属性的属性值又是一个对象,这个对象默认有个constructor属性,这个属性的属性值指向函数本身。

如上图,superType是一个函数,右侧的方框就是它的原型。

原型作为对象,属性的集合,默认有个constructor属性,有的还有其他属性。比如object的原型里面就有好几个其他属性。

同时也可以在自己自定义的方法的prototype中新增自己的属性

1 function Fn(){};
2 Fn.prototype.name=\'张三\';
3 Fn.prototype.getYear=function () {
4     return 1988;
5 };

从画的结构图就可以看出自己手动添加的name属性和getYear方法被添加到了prototype原型中。再看下面的例子

1 function Fn(){};
2 Fn.prototype.name=\'张三\';
3 Fn.prototype.getYear=function () {
4     return 1988;
5 };
6 var fn=new Fn();
7 console.log(fn.name);
8 console.log(fn.getYear());

Fn是一个函数,fn对象是从Fn函数new出来的,这样fn对象就可以调用Fn.prototype中的属性和方法。

每个对象都有一个隐藏的属性——_proto_,这个属性引用了创建这个函数的原型,即fn._proto_ === Fn.prototype

这里的_proto_称之为对象的隐式原型。

以上是关于深入理解javascript原型和闭包——prototype原型的主要内容,如果未能解决你的问题,请参考以下文章

深入理解javascript原型和闭包(转)

深入理解javascript原型和闭包——prototype原型

深入理解javascript原型和闭包 (转)

深入理解javascript原型和闭包(完结)

深入理解javascript原型和闭包——隐式原型

深入理解javascript原型和闭包——继承