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 相关文章推荐
IE与firefox之jquery用法区别
Oct 03 Javascript
禁用页面部分JavaScript不是全部而是部分
Sep 03 Javascript
JavaScript字符串对象split方法入门实例(用于把字符串分割成数组)
Oct 16 Javascript
JavaScript实现自动变换表格边框颜色
May 08 Javascript
jquery实现仿JqueryUi可拖动的DIV实例
Jul 31 Javascript
Javascript实现检测客户端类型代码封包
Dec 03 Javascript
jquery插件jquery.dragscale.js实现拖拽改变元素大小的方法(附demo源码下载)
Feb 25 Javascript
JavaScript对象封装的简单实现方法(3种方法)
Jan 03 Javascript
js字符限制(字符截取) 一个中文汉字算两个字符
Sep 12 Javascript
jQuery 导航自动跟随滚动的实现代码
May 30 jQuery
js实现的在本地预览图片功能示例
Nov 09 Javascript
小程序实现侧滑删除功能
Jun 25 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
一个阿拉伯数字转中文数字的函数
2006/10/09 PHP
php页面跳转代码 输入网址跳转到你定义的页面
2013/03/28 PHP
深入PHP empty(),isset(),is_null()的实例测试详解
2013/06/06 PHP
学习php设计模式 php实现观察者模式(Observer)
2015/12/09 PHP
Laravel5权限管理方法详解
2016/07/26 PHP
基于php实现的验证码小程序
2016/12/13 PHP
ThinkPHP框架实现数据增删改
2017/05/07 PHP
PHP laravel中的多对多关系实例详解
2017/06/07 PHP
PHP更安全的密码加密机制Bcrypt详解
2017/06/18 PHP
兼容多浏览器的iframe自适应高度(ie8 、谷歌浏览器4.0和 firefox3.5.3)
2009/11/04 Javascript
boxy基于jquery的弹出层对话框插件扩展应用 弹出层选择器
2010/11/21 Javascript
javascript实现鼠标放上后下边对应内容变换的效果
2015/08/06 Javascript
JS基于Ajax实现的网页Loading效果代码
2015/10/27 Javascript
jQuery循环遍历子节点并获取值的方法
2016/04/14 Javascript
JavaScript实现Base64编码转换
2016/04/23 Javascript
JS获取html元素的标记名实现方法
2016/10/08 Javascript
jQuery实现菜单栏导航效果
2017/08/15 jQuery
js移动端图片压缩上传功能
2020/08/18 Javascript
node.js到底要不要加分号浅析
2018/07/11 Javascript
vuecli项目构建SSR服务端渲染的实现
2020/10/30 Javascript
[01:36:57]【09DOTA2第一视角】小骷髅
2014/04/16 DOTA
Django读取Mysql数据并显示在前端的实例
2018/05/27 Python
python梯度下降法的简单示例
2018/08/31 Python
python隐藏类中属性的3种实现方法
2019/12/19 Python
Pycharm内置终端及远程SSH工具的使用教程图文详解
2020/03/19 Python
django使用多个数据库的方法实例
2021/03/04 Python
介绍CSS3使用技巧5个
2009/04/02 HTML / CSS
英国现代、当代和设计师家具店:Furntastic
2020/07/18 全球购物
荷兰浴室和卫浴网上商店:Badkamerxxl.nl
2020/10/06 全球购物
服务之星获奖感言
2014/01/21 职场文书
幼儿园中秋节活动反思
2014/02/16 职场文书
2014年安全生产大检查方案
2014/05/13 职场文书
个人专业技术总结
2015/03/05 职场文书
2015年毕业生自荐信范文
2015/03/24 职场文书
经典爱情感言
2015/08/03 职场文书
MySQL 十大常用字符串函数详解
2021/06/30 MySQL