原型,构造器和实例对象的关系

每个构造函数都有一个原型对象,原型对象包含一个指向构造函数的指针,而实例都包含一个指向构造函数原型的对象的内部指针。

1,每个构造函数都一个原型对象##

我们创建的每一个函数都有一个 prototype 属性,这个属性是一个指针,指向一个对象。

例子:

	// 构造函数
	var SuperPlane = function(){
		this.name = "xxx";
	}
	SuperPlane.prototype.sayName = function(){
		console.log( this.name );
	} 

普通函数也具有这个属性,但是,不对函数进行 new 操作的话,原型对象也就没有任何意义。函数内部的 this 也会指向 window。

2,原型对象包含一个指向构造函数的指针##

在默认情况下,所有原型对象都会自动获得一个 constructor 属性。就用刚才那个例子来说:

SuperPlane.prototype.constructor = SuperPlane

下面配一张图说明

上图可以看到 SuperPlane 构造函数中 prototype 对象包含着 constructor 属性。

3,实例包含一个指向构造函数原型对象的内部指针##

javascript 为对象创建了一个内部属性 [proto] ,这个属性指向了构造函数的原型对象。

例子:

var plane2 = new SuperPlane()

这个内部属性,不可以直接访问,但是浏览器调试的时候可以看到,如下图:

想一下当构造函数的原型属性等于另一个对象的实例的时候?

总结##

用一张图来代替想说的话

posted @ 2015-09-23 10:49  jienyi  阅读(364)  评论(0编辑  收藏  举报