一个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 相关文章推荐
jQuery 学习 几种常用方法
Jun 11 Javascript
php跨域调用json的例子
Nov 13 Javascript
JS+JSP checkBox 全选具体实现
Jan 02 Javascript
原生js和jQuery写的网页选项卡特效对比
Apr 27 Javascript
javascript实现图片轮播效果
Jan 20 Javascript
JS实现全屏的四种写法
Dec 30 Javascript
详解Vue 普通对象数据更新与 file 对象数据更新
Apr 26 Javascript
在JS中如何把毫秒转换成规定的日期时间格式实例
May 11 Javascript
Angular之toDoList的实现代码示例
Dec 02 Javascript
Node.js笔记之process模块解读
May 31 Javascript
CSS3 动画卡顿性能优化的完美解决方案
Sep 20 Javascript
解决layer弹出层中表单不起作用的问题
Sep 09 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基础知识:类与对象(4) 范围解析操作符(::)
2006/12/13 PHP
在PHP中检查PHP文件是否有语法错误的方法
2009/12/23 PHP
详解Grunt插件之LiveReload实现页面自动刷新(两种方案)
2015/07/31 PHP
php使用crypt()函数进行加密
2017/06/08 PHP
执行iframe中的javascript方法
2008/10/07 Javascript
CCPry JS类库 代码
2009/10/30 Javascript
Javascript获取窗口(容器)的大小及位置参数列举及简要说明
2012/12/09 Javascript
用jquery模仿的a的title属性的例子
2014/10/22 Javascript
JavaScript中的逻辑判断符&&、||与!介绍
2014/12/31 Javascript
利用jQuery的动画函数animate实现豌豆发射效果
2016/08/28 Javascript
jQuery如何防止Ajax重复提交
2016/10/14 Javascript
微信小程序 配置文件详细介绍
2016/12/14 Javascript
快速实现jQuery多级菜单效果
2017/02/01 Javascript
简述jQuery Easyui一些用法
2017/08/01 jQuery
mui 打开新窗口的方式总结及注意事项
2017/08/20 Javascript
JS基于正则表达式实现的密码强度验证功能示例
2017/09/21 Javascript
详解Angular6 热加载配置方案
2018/08/18 Javascript
Vue Cli3 创建项目的方法步骤
2018/10/15 Javascript
Javascript之高级数组API的使用实例
2019/03/08 Javascript
bootstrap-table formatter 使用vue组件的方法
2019/05/09 Javascript
js实现多张图片每隔一秒切换一张图片
2019/07/29 Javascript
vue实现编辑器键盘抬起时内容跟随光标距顶位置向上滚动效果
2020/05/28 Javascript
原生JavaScript实现拖动校验功能
2020/09/29 Javascript
[01:08:17]2018DOTA2亚洲邀请赛3月29日 小组赛B组 EG VS VGJ.T
2018/03/30 DOTA
初学Python函数的笔记整理
2015/04/07 Python
十个Python程序员易犯的错误
2015/12/15 Python
在Python程序员面试中被问的最多的10道题
2017/12/05 Python
python实现excel读写数据
2021/03/02 Python
Python使用Pandas库常见操作详解
2020/01/16 Python
图库照片、免版税图片、矢量艺术、视频片段:Depositphotos
2019/08/02 全球购物
基层干部2014全国两会学习心得体会
2014/03/10 职场文书
行政监察建议书
2014/05/19 职场文书
公司合作协议范文
2014/10/01 职场文书
不服劳动仲裁起诉书
2015/05/20 职场文书
MIME类型中application/xml与text/xml的区别介绍
2022/01/18 HTML / CSS
MySQL分区路径子分区再分区
2022/04/13 MySQL