码迷,mamicode.com
首页 > 其他好文 > 详细

继承[第6章-面向对象的程序设计 笔记3]

时间:2015-05-07 23:58:05      阅读:276      评论:0      收藏:0      [点我收藏+]

标签:

许多 OO 语言都支持两种继承方式:接口继承和实现继承。接口继承只继承方法签名,而实现继承则继承实际的方法。如前所述,由于函数没有签名,在 ECMAScript 中无法实现接口继承。 ECMAScript 只支持实现继承, 而且其实现继承主要是依靠原型链来实现的。

 

原型链

    ECMAScript 中描述了原型链的概念,并将原型链作为实现继承的主要方法。其基本思想是利用原

型让一个引用类型继承另一个引用类型的属性和方法。

简单回顾一下构造函数、原型和实例的关系:每个构造函数都有一个原型对象,原型对象都包含一个指向构造函数的指针,而实例都包含一个指向原型对象的内部指针。

那么,假如我们让原型对象等于另一个类型的实例,结果会怎么样呢?

显然,此时的原型对象将包含一个指向另一个原型的指针,相应地,另一个原型中也包含着一个指向另一个构造函数的指针。假如另一个原型又是另一个类型的实例,那么上述关系依然成立,如此层层递进,就构成了实例与原型的链条。

实现原型链有一种基本模式大致如下:

function SuperType(){

 this.property = true;

}

SuperType.prototype.getSuperValue = function(){

 return this.property;

};

 

function SubType(){

 this.subproperty = false;

}

//继承了 SuperType

SubType.prototype = new SuperType();

 

SubType.prototype.getSubValue = function (){

 return this.subproperty;

};

var instance = new SubType();

alert(instance.getSuperValue()); //true 

    以上代码定义了两个类型: SuperType 和 SubType 。每个类型分别有一个属性和一个方法。

    主要区别是 SubType 继承了 SuperType ,而继承是通过创建 SuperType 的实例,并将该实例赋给

SubType.prototype 实现的。

    实现的本质是重写原型对象,代之以一个新类型的实例。换句话说,原来存在于 SuperType 的实例中的所有属性和方法,现在也存在于 SubType.prototype 中了。在确立了继承关系之后,我们给SubType.prototype 添加了一个方法,这样就在继承了 SuperType 的属性和方法的基础上又添加了一个新方法。

如下所示: 

技术分享 

继承[第6章-面向对象的程序设计 笔记3]

标签:

原文地址:http://www.cnblogs.com/aries1991/p/4486252.html

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