一个JavaScript继承的实现


Posted in Javascript onOctober 24, 2006

Author:尹伟铭

Blog:http://my.donews.com/yinwm/

如我前面的文章说的,对于JavaScript,一个类,就是一个function,他的类方法(也就是static的)都是作为这个function的一部分,而实例方法,都是在prototype上面的。
function ClassA() {
}

ClassA.staticMethod = function () {
}

ClassA.prototype.instanceMethod = function () {
}

在我这个实现当中,一个类的继承是拷贝父类的所有类方法,这样子类就有了父类的静态方法。
然后让子类的prototype.prototype指向父类的prototype.
然后可以根据自己的需要,重写一些方法。
function ClassB() {
}
ClassB.staticMethod = ClassA.staticMethod;
ClassB.prototype.prototype = ClassA.prototype;
ClassB.prototype.instanceMethod = function () {
// method 2
}

对于子类,使用一个prototype的链,来实现方法的实例方法的继承。之所以选择这种实现方法,是因为子类是要重写其中的某些方法的。而prototype又是一个reference,所以直接的写作ClassB.prototype = ClassA.prototype,会在重写ClassB的实例方法的同时,破坏ClassA的实例方法。而修改后的方法则会屏蔽父类的。

寻找方法的顺序是,instanceA.prototype.method -> ClassA.prototype.
此时对于类方法的继承,已经实现,现在需要实现在子类中,调用父类的方法。
对于Java,这样的使用是很平常的
public void method() {
super.method();
}
在JavsScript中,为了实现此类功能,所以必须保留一个parent的reference,指向ParentClass.prototype.
ClassB.prototype.parent = ClassA.prototype.
那么在instanceB里面调用this.parent.method.call(this);就可以使用父类的方法了。使用call调用,是为了把自己的数据传到父类。更漂亮的解决方法,我还没有想到。

所以完成的代码是
function ClassA() {
}

ClassA.prototype.method1 = function () {
}

ClassA.staticMethod = function () {
}

function ClassB(){
}

ClassB.staticMethod = ClassA.staticMethod;

ClassB.prototype.prototype = ClassB.prototype.parent = ClassA.prototype;

这个我抽象出来一个extend方法,

var LCore = function () {
}

LCore.extend = function (destination, source) {
// copy all functons
for (var prop in source) {
if (prop == “prototype”) {
continue;
}

destination.prototype[prop] = source[prop];
}

// make a reference for parent and reference prototype
destination.prototype.prototype = destination.prototype.parent = source.prototype;

return destination;

Javascript 相关文章推荐
javascript数组的扩展实现代码集合
Jun 01 Javascript
javascript入门基础之私有变量
Feb 23 Javascript
JavaScript全局函数使用简单说明
Mar 11 Javascript
批量实现面向对象的实例代码
Jul 01 Javascript
从数组中随机取x条不重复数据的JS代码
Dec 24 Javascript
Jquery实现瀑布流布局(备有详细注释)
Jul 31 Javascript
JS之获取样式的简单实现方法(推荐)
Sep 13 Javascript
vue vue-Router默认hash模式修改为history需要做的修改详解
Sep 13 Javascript
使用angular-cli webpack创建多个包的方法
Oct 16 Javascript
Vue 通过公共字段,拼接两个对象数组的实例
Nov 07 Javascript
JavaScript代码实现微博批量取消关注功能
Feb 05 Javascript
浅谈react路由传参的几种方式
Mar 23 Javascript
动态加载js的几种方法
Oct 23 #Javascript
用js怎么把&字符换成"&amp:"
Oct 19 #Javascript
对联广告js flash激活
Oct 19 #Javascript
怎么让脚本或里面的函数在所有图片都载入完毕的时候执行
Oct 17 #Javascript
菜单效果
Oct 14 #Javascript
Using the TextRange Object
Oct 14 #Javascript
使用TextRange获取输入框中光标的位
Oct 14 #Javascript
You might like
PHP提取中文首字母
2008/04/09 PHP
简单的PHP留言本实例代码
2010/05/09 PHP
php设计模式 Factory(工厂模式)
2011/06/26 PHP
php检测useragent版本示例
2014/03/24 PHP
php下载文件源代码(强制任意文件格式下载)
2014/05/09 PHP
php实现base64图片上传方式实例代码
2017/02/22 PHP
php生成网页桌面快捷方式
2017/05/05 PHP
为超链接加上disabled后的故事
2010/12/10 Javascript
JavaScript 命名空间 使用介绍
2013/08/29 Javascript
轻松创建nodejs服务器(9):实现非阻塞操作
2014/12/18 NodeJs
Window.Open打开窗体和if嵌套代码
2016/04/15 Javascript
阿里云ecs服务器中安装部署node.js的步骤
2016/10/08 Javascript
vue制作加载更多功能的正确打开方式
2016/10/12 Javascript
Vue实现点击后文字变色切换方法
2018/02/11 Javascript
layer插件select选中默认值的方法
2018/08/14 Javascript
基于vue中keep-alive缓存问题的解决方法
2018/09/21 Javascript
Vue 3.x+axios跨域方案的踩坑指南
2019/07/04 Javascript
JS 实现发送短信验证码的“59秒后重新发送验证短信”功能
2019/08/23 Javascript
[52:29]DOTA2上海特级锦标赛主赛事日 - 2 胜者组第一轮#3Secret VS OG第三局
2016/03/03 DOTA
学习Python selenium自动化网页抓取器
2018/01/20 Python
详解Python 实现元胞自动机中的生命游戏(Game of life)
2018/01/27 Python
Python实现合并同一个文件夹下所有txt文件的方法示例
2018/04/26 Python
编写多线程Python服务器 最适合基础
2018/09/14 Python
python爬虫 爬取58同城上所有城市的租房信息详解
2019/07/30 Python
matplotlib.pyplot画图并导出保存的实例
2019/12/07 Python
pandas数据处理之绘图的实现
2020/06/15 Python
Python实现验证码识别
2020/06/15 Python
Ajax实现页面无刷新留言效果
2021/03/24 Javascript
质量工程师岗位职责
2013/11/16 职场文书
物业保安员岗位职责
2014/03/14 职场文书
社团活动总结格式
2014/08/29 职场文书
2014年重阳节活动策划方案书
2014/09/16 职场文书
教师四风自我剖析材料
2014/09/30 职场文书
2015暑假社会调查报告
2015/07/13 职场文书
2015年中学团委工作总结
2015/07/22 职场文书
浅谈Redis 中的过期删除策略和内存淘汰机制
2022/04/03 Redis