javascript是怎么继承的介绍


Posted in Javascript onJanuary 05, 2012

第一个阶段:

function A(){ 
this.funB = function(){ 
alert('A:funB'); 
}; 
} 
A.prototype = { 
funA:function(){ 
alert('A:funA'); 
} 
}; 
function B(){ 
} 
function extend(sub,parent){ 
sub.prototype = new parent(); 
sub.prototype.constructor = sub; 
} 
extend(B,A); 
var b = new B(); 
b.funA(); // out 'A:funA' 
b.funB(); // out 'A:funB' 
alert(b instanceof A); // out "true"

想必大家一眼就看出什么意思了,先是定义了A,B两个类,然后使用extend方法来让B继承A类。extend的原理就是让父类 new 到子类的prototype上。
用instanceof来检测也为true,想要让instanceof为true,那就必须两个类的prototype对象要为同一个object,不管是间接或直接的。
这样的方式有没有问题呢?在通常面向对象语言中,子类在继承父类时,是不会触发父类的构造函数执行,而这里是父类是在继承时执行的。
第二个阶段
function A(){ 
this.Astr = 'hello A'; 
} 
A.prototype = { 
funA:function(){ 
alert(this.Astr); 
} 
}; 
function B(){ 
arguments.callee.superclass && arguments.callee.superclass.apply(this,arguments); 
this.Bstr = 'hello B'; 
} 
B.prototype = { 
funB:function(){ 
alert(this.Bstr); 
} 
}; 
function C(){ 
arguments.callee.superclass && arguments.callee.superclass.apply(this,arguments); 
alert(this.Astr); 
alert(this.Bstr); 
} 
function extend(sub,parent){ 
var subproto = sub.prototype; 
sub.prototype = parent.prototype; 
typeof subproto != 'object' && (subproto = {}); 
typeof sub.prototype != 'object' && (sub.prototype = {}); 
for(var i in subproto){ 
sub.prototype[i] = subproto[i]; 
} 
sub.superclass = parent; 
} 
//B 继承 A 
extend(B,A); 
//C 继承 B 
extend(C,B); 
var c = new C(); // out 'hello A','hello B' 
c.funA(); //out 'hello A' 
c.funB(); // out 'hello B' 
alert(c instanceof A) // out true 
alert(c instanceof B) // out true;

这里对extend方法做了一些改动,这里有个约定,每个子类都拥有一个superclass的属性,用来引用她所继承的父类,用一个空函数proto来获得父类的prototype,实例化给子类的prototype,这样就没有执行父类构造器。
而是在子类的构造器中用下来一段代码来执行约定要的父类构造器。
arguments.callee.superclass && arguments.callee.superclass.apply(this,argumengs);

这样就完成了类的继承。
对于上面的代码有没有更方便的继承写法呢,修改Function的原型来看看:
Function.prototype.extend = function(parent){ 
var subproto = this.prototype; 
this.prototype = parent.prototype; 
typeof subproto != 'object' && (subproto = {}); 
typeof this.prototype != 'object' && (this.prototype = {}); 
for(var i in subproto){ 
this.prototype[i] = subproto[i]; 
} 
this.superclass = parent; 
return this; 
} 
function A(){ 
this.Astr = 'hello A'; 
} 
A.prototype = { 
funA:function(){ 
alert(this.Astr); 
} 
}; 
var B = function(){ 
arguments.callee.superclass && arguments.callee.superclass.apply(this,arguments); 
this.Bstr = 'hello B'; 
} 
B.prototype = { 
funB:function(){ 
alert(this.Astr); 
} 
}; 
B.extend(A); 
var C = function(){ 
arguments.callee.superclass && arguments.callee.superclass.apply(this,arguments); 
alert(this.Astr); 
alert(this.Bstr); 
}.extend(B); 
var c = new C(); // out 'hello A','hello B' 
c.funA(); //out 'hello A' 
c.funB(); // out 'hello B' 
alert(c instanceof A) // out true 
alert(c instanceof B) // out true;

这里的extend做的事情是: subproto引用子类的原prototype ,将子类的prototype 指向 父类的prototype对象,这样就继承了父类(这样的目的是让 子类实例 instanceof 父类 为 true)。然后历遍subproto,将原prototype的成员添加到现prototype上,这样子类重名的重名的成员就会覆盖父类的成员。最后将子类的属性superclass 指向 父类。
js继承的关键就是保持原型链的唯一性,instanceof就以判断实例的__proto__是否和父类的prototype为同一Object.

作者 cnblogs OD

Javascript 相关文章推荐
详细讲解JS节点知识
Jan 31 Javascript
javascript 二进制运算技巧解析
Nov 27 Javascript
javascript读写json示例
Apr 11 Javascript
javascript计时器详解
Feb 28 Javascript
JS+CSS模拟可以无刷新显示内容的留言板实例
Mar 03 Javascript
JavaScript实现向OL列表内动态添加LI元素的方法
Mar 21 Javascript
JS实现自动切换文字的导航效果代码
Aug 27 Javascript
JS留言功能的简单实现案例(推荐)
Jun 23 Javascript
jQuery焦点图左右转换效果
Dec 12 Javascript
AngularJS中$apply方法和$watch方法用法总结
Dec 13 Javascript
ES6中的rest参数与扩展运算符详解
Jul 18 Javascript
JavaScript定时器setTimeout()和setInterval()详解
Aug 18 Javascript
js 链式延迟执行DOME
Jan 04 #Javascript
常见效果实现之返回顶部(结合淡入、淡出、减速滚动)
Jan 04 #Javascript
Textarea与懒惰渲染实现代码
Jan 04 #Javascript
js中有关IE版本检测
Jan 04 #Javascript
国外大牛IE版本检测!现在IE都到9了,IE检测代码
Jan 04 #Javascript
IE的有条件注释判定IE版本详解(附实例代码)
Jan 04 #Javascript
js变量以及其作用域详解
Jul 18 #Javascript
You might like
PHP微信支付开发实例
2016/06/22 PHP
php命令行写shell实例详解
2018/07/19 PHP
js加解密 脚本解密
2008/02/22 Javascript
JS小功能(操作Table--动态添加删除表格及数据)实现代码
2013/11/28 Javascript
jQuery中.live()方法的用法深入解析
2013/12/30 Javascript
图片翻转效果具体实现代码
2014/01/09 Javascript
javascript实现在某个元素上阻止鼠标右键事件的方法和实例
2014/08/12 Javascript
Jquery中$.post和$.ajax的用法小结
2015/04/28 Javascript
JS中innerHTML和pasteHTML的区别实例分析
2016/06/22 Javascript
Javascript 实现匿名递归的实例代码
2017/05/25 Javascript
详解webpack分离css单独打包
2017/06/21 Javascript
详解在vue-cli中使用路由
2017/09/25 Javascript
纯js代码生成可搜索选择下拉列表的实例
2018/01/11 Javascript
js实现敏感词过滤算法及实现逻辑
2018/07/24 Javascript
vue+node实现图片上传及预览的示例方法
2018/11/22 Javascript
解决Vue打包后访问图片/图标不显示的问题
2019/07/25 Javascript
python生成随机mac地址的方法
2015/03/16 Python
Python基于回溯法子集树模板解决全排列问题示例
2017/09/07 Python
Python 模拟购物车的实例讲解
2017/09/11 Python
python简易实现任意位数的水仙花实例
2018/11/13 Python
解决Django加载静态资源失败的问题
2019/07/28 Python
你应该知道的Python3.6、3.7、3.8新特性小结
2020/05/12 Python
Python urllib2运行过程原理解析
2020/06/04 Python
Django DRF认证组件流程实现原理详解
2020/08/17 Python
纯CSS3实现的阴影效果
2014/12/24 HTML / CSS
CSS3实现可翻转的hover效果
2018/05/23 HTML / CSS
英国最大的独立摄影零售商:Park Cameras
2019/11/27 全球购物
什么叫做SQL注入,如何防止
2016/10/04 面试题
linux面试题参考答案(4)
2013/01/28 面试题
linux面试题参考答案(7)
2014/07/24 面试题
Java中有几种类型的流?JDK为每种类型的流提供了一些抽象类以供继承,请说出他们分别是哪些类?
2012/05/30 面试题
医学院毕业生自荐信
2013/11/08 职场文书
优秀企业获奖感言
2014/02/01 职场文书
KTV的创业计划书范文
2014/02/02 职场文书
革命先烈的英雄事迹材料
2014/02/15 职场文书
2015年见习期工作总结
2014/12/12 职场文书