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 相关文章推荐
Javascript中eval函数的使用方法与示例
Apr 09 Javascript
jQuery移除元素自动解绑事件实现思路及代码
May 31 Javascript
jQuery+PHP+MySQL实现无限级联下拉框效果
Feb 19 Javascript
基于JS实现导航条之调用网页助手小精灵的方法
Jun 17 Javascript
使用微信内嵌H5网页解决JS倒计时失效问题
Jan 13 Javascript
js实现适配不同的屏幕大小
Apr 10 Javascript
使用socket.io实现简单聊天室案例
Jan 02 Javascript
如何在Vue.js中实现标签页组件详解
Jan 02 Javascript
vue多次循环操作示例
Feb 08 Javascript
jQuery/JS监听input输入框值变化实例
Oct 17 jQuery
何时/使用 Vue3 render 函数的教程详解
Jul 25 Javascript
JS 4个超级实用的小技巧 提升开发效率
Oct 05 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
SSI指令
2006/11/25 PHP
关于PHP结束标签的使用细节探讨及联想
2013/03/04 PHP
ThinkPHP的MVC开发机制实例解析
2014/08/23 PHP
php利用cookie实现自动登录的方法
2014/12/10 PHP
CI框架数据库查询之join用法分析
2016/05/18 PHP
php pdo连接数据库操作示例
2019/11/18 PHP
js中AppendChild与insertBefore的用法详细解析
2013/12/16 Javascript
jquery设置按钮停顿3秒不可用
2014/03/07 Javascript
jQuery插件datatables使用教程
2016/04/21 Javascript
ionic实现滑动的三种方式
2016/08/27 Javascript
js转html实体的方法
2016/09/27 Javascript
如何使用jquery实现文字上下滚动效果
2016/10/12 Javascript
jQuery实现动态文字搜索功能
2017/01/05 Javascript
js自定义QQ菜单效果
2017/01/10 Javascript
三种方式实现瀑布流布局
2017/02/10 Javascript
Vue2.0生命周期的理解
2018/08/20 Javascript
vue2.0自定义指令示例代码详解
2019/04/25 Javascript
为什么Vue3.0使用Proxy实现数据监听(defineProperty表示不背这个锅)
2019/10/14 Javascript
vue中keep-alive内置组件缓存的实例代码
2020/04/16 Javascript
vue tab滚动到一定高度,固定在顶部,点击tab切换不同的内容操作
2020/07/22 Javascript
js 压缩图片的示例(只缩小体积,不更改图片尺寸)
2020/10/21 Javascript
python3编写C/S网络程序实例教程
2014/08/25 Python
在Python中使用SimpleParse模块进行解析的教程
2015/04/11 Python
Python SQLite3数据库日期与时间常见函数用法分析
2017/08/14 Python
windows下python安装pip图文教程
2018/05/25 Python
Python可迭代对象操作示例
2019/05/07 Python
Python OpenCV读取显示视频的方法示例
2020/02/20 Python
推荐10个HTML5响应式框架
2016/02/25 HTML / CSS
奢华的意大利皮革手袋:Bene Handbags
2019/10/29 全球购物
Ego Shoes官网:英国时髦鞋类品牌
2020/10/19 全球购物
运动会通讯稿500字
2014/02/20 职场文书
微笑服务演讲稿
2014/05/13 职场文书
设计专业毕业生求职信
2014/06/25 职场文书
2014年社区综治工作总结
2014/11/17 职场文书
2016年重阳节慰问信
2015/12/01 职场文书
优秀家长事迹材料(2016推荐版)
2016/02/29 职场文书