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 window.onload 加载多个函数的方法
Nov 02 Javascript
用jQuery扩展自写的 UI导航
Jan 13 Javascript
js 图片等比例缩放代码
May 13 Javascript
js中prototype用法详细介绍
Nov 14 Javascript
用js通过url传参把数据从一个页面传到另一个页面
Sep 01 Javascript
微信小程序 wx:for的使用实例详解
Apr 27 Javascript
Angular X中使用ngrx的方法详解(附源码)
Jul 10 Javascript
js实现音乐播放控制条
Sep 09 Javascript
JS实现的JSON数组去重算法示例
Apr 11 Javascript
JavaScript中变量、指针和引用功能与操作示例
Aug 04 Javascript
Node中对非阻塞I/O、事件循环的知识点总结
Jan 05 Javascript
vue实现户籍管理系统
May 29 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调用三种数据库的方法(1)
2006/10/09 PHP
php提交表单时判断 if($_POST[submit])与 if(isset($_POST[submit])) 的区别
2011/02/08 PHP
本地计算机无法启动Apache故障处理
2014/08/08 PHP
php快速查找数据库中恶意代码的方法
2015/04/01 PHP
php计算税后工资的方法
2015/07/28 PHP
weiphp微信公众平台授权设置
2016/01/04 PHP
谈谈php对接芝麻信用踩的坑
2016/12/01 PHP
微信第三方登录(原生)demo【必看篇】
2017/05/26 PHP
javascript比较文档位置
2008/04/08 Javascript
javascript 动态添加事件代码
2008/11/30 Javascript
JavaScript入门教程 Cookies
2009/01/31 Javascript
Javascript 原型和继承(Prototypes and Inheritance)
2009/04/01 Javascript
javascript禁用键盘功能键让右击及其他键无效
2013/10/09 Javascript
用jquery实现动画跳到顶部和底部(这个比较简单)
2014/09/01 Javascript
js根据鼠标移动速度背景图片自动旋转的方法
2015/02/28 Javascript
JS实现的仿东京商城菜单、仿Win右键菜单及仿淘宝TAB特效合集
2015/09/28 Javascript
详解Javacript和AngularJS中的Promises
2016/02/09 Javascript
浅析location.href跨窗口调用函数
2016/11/22 Javascript
Easyui笔记2:实现datagrid多行删除的示例代码
2017/01/14 Javascript
深入理解vue $refs的基本用法
2017/07/13 Javascript
elemetUi 组件--el-upload实现上传Excel文件的实例
2017/10/27 Javascript
jQuery发请求传输中文参数乱码问题的解决方案
2018/05/22 jQuery
python统计文本字符串里单词出现频率的方法
2015/05/26 Python
使用pandas实现连续数据的离散化处理方式(分箱操作)
2019/11/22 Python
python求一个字符串的所有排列的实现方法
2020/02/04 Python
python数据库开发之MongoDB安装及Python3操作MongoDB数据库详细方法与实例
2020/03/18 Python
keras 指定程序在某块卡上训练实例
2020/06/22 Python
python爬虫线程池案例详解(梨视频短视频爬取)
2021/02/20 Python
南威尔士家居商店:Leekes
2016/10/25 全球购物
联想印度官方网上商店:Lenovo India
2019/08/24 全球购物
房屋登记授权委托书范本
2014/10/09 职场文书
《玩出了名堂》教学反思
2016/02/17 职场文书
一封真诚的自荐信帮你赢得机会
2019/05/07 职场文书
python tqdm用法及实例详解
2021/06/16 Python
详解SQL报错盲注
2022/07/23 SQL Server
Apache自带的ab压力测试工具的实现
2022/07/23 Servers