一个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 浮动导航栏实现代码
Aug 27 Javascript
jQuery中slice()方法用法实例
Jan 07 Javascript
Highcharts使用简例及异步动态读取数据
Dec 30 Javascript
Bootstrap每天必学之折叠
Apr 12 Javascript
js捕捉键盘事件和按键键值的方法
Oct 10 Javascript
详解js数组的完全随机排列算法
Dec 16 Javascript
如何学JavaScript?前辈的经验之谈
Dec 28 Javascript
JS实现无缝循环marquee滚动效果
May 22 Javascript
Vue页面骨架屏的实现方法
May 22 Javascript
JavaScript自动生成 年月范围 选择功能完整示例【基于jQuery插件】
Sep 03 jQuery
浅谈Vue中render中的h箭头函数
Nov 07 Javascript
原生js实现文件上传、下载、封装等实例方法
Jan 05 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
《星际争霸重制版》兵种对比图鉴
2020/03/02 星际争霸
php 多个submit提交表单 处理方法
2009/07/07 PHP
PHP substr 截取字符串出现乱码问题解决方法[utf8与gb2312]
2011/12/16 PHP
PHP 日,周,月点击排行统计
2012/01/11 PHP
PHP实现的登录页面信息提示功能示例
2017/07/24 PHP
详解php伪造Referer请求反盗链资源
2019/01/24 PHP
redis+php实现微博(二)发布与关注功能详解
2019/09/23 PHP
让getElementsByName适应IE和firefox的方法
2007/09/24 Javascript
关于B/S判断浏览器断开的问题讨论
2008/10/29 Javascript
Webkit的跨域安全问题说明
2011/09/13 Javascript
js文件缓存之版本管理详解
2013/07/05 Javascript
js 时间函数应用加、减、比较、格式转换的示例代码
2013/08/23 Javascript
浅谈JavaScript实现面向对象中的类
2014/12/09 Javascript
瀑布流的实现方式(原生js+jquery+css3)
2020/06/28 Javascript
全面解析标签页的切换方式
2016/08/21 Javascript
JSON 必知必会 观后记
2016/10/27 Javascript
Vue获取DOM元素样式和样式更改示例
2017/03/07 Javascript
深入理解 JavaScript 中的 JSON
2017/04/06 Javascript
Vue 实例事件简单示例
2019/09/19 Javascript
微信小程序获取当前位置和城市名
2019/11/13 Javascript
vue移动端使用canvas签名的实现
2020/01/15 Javascript
[04:50]DOTA2亚洲邀请赛小组赛第四日 TOP10精彩集锦
2015/02/02 DOTA
Python制作词云的方法
2018/01/03 Python
详解Python3的TFTP文件传输
2018/06/26 Python
python获取服务器响应cookie的实例
2018/12/28 Python
为什么黑客都用python(123个黑客必备的Python工具)
2020/01/31 Python
python实现简单文件读写函数
2021/02/25 Python
玛蒂尔达简服装:Matilda Jane Clothing
2019/02/13 全球购物
Andrew Marc官网:设计师外套的领先制造商
2019/10/30 全球购物
出生医学证明书
2014/09/15 职场文书
工伤死亡理赔协议书
2014/10/20 职场文书
祝酒词范文
2015/08/12 职场文书
文案策划岗位个人自我评价(范文)
2019/08/08 职场文书
Nginx同一个域名配置多个项目的实现方法
2021/03/31 Servers
基于tensorflow权重文件的解读
2021/05/26 Python
Redis高可用集群redis-cluster详解
2022/03/20 Redis