什么是原型和原型链不再赘述。
由之前的博客,知道可以得出如下俩个结论:
- 对象的原型链和该对象对应的类的原型指向同一空间
- 子类对象的原型中的原型链和父类的原型指向同一个空间。
直接看父类和子类之间、普通类和Function,Object类之间的原型和原型链之间的关系。
Function类
注意是大写的Function,那么这个和function有什么区别呢?
之间说function定义的内容,既是函数也是类,还是对象。这个function定义的对象就是Function类的对象,上述第一条结论得出,Function类的原型对象应该等于由function定义的类的原型链。
Function类自身还有一个原型链,他指向的也是Function类的原型对象,即自己指向了自己,是一个终点。
var Fun = function(){
this.one = 10;
}
console.log(Function.prototype === Function.__proto__); //true
console.log(Fun.__proto__ === Function.prototype); //true
特殊说明
prototype是类的原型对象
__ proto __是原型链
一般以(下划线下划线)开头的变量都是系统隐藏的变量,一般是不会拿出来的,这里是为了演示原型链的结论。
Object类
但一个类,没有指明其父类,如下:
var Parent = function(){
}
console.log(Parent.prototype);
console.log(Object.prototype);
比对后看到,Object的原型对象和Parent的原型对象中的原型链是一样的。
我们再测试一下下面语句:
console.log(Object.prototype === Parent.prototype.__proto__); //结果为true
可以的出这样的结论:
没有父类的类的原型对象的原型链指向Obj的原型。
Object类中原型对象也有原型链,这个原型链是null。
总结
总结四条结论:
- 没有父类的类的原型对象的原型链指向Obj的原型。
- 类的原型链指向Function的原型。
- Object的原型链指向Function的原型对象。
- Object的原型的原型链等于null
图可以更直观的看: