一个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 相关文章推荐
特殊字符、常规符号及其代码对照表
Jun 26 Javascript
Javascript中Array.prototype.map()详解
Oct 22 Javascript
js使用split函数按照多个字符对字符串进行分割的方法
Mar 20 Javascript
如何用jQuery实现ASP.NET GridView折叠伸展效果
Sep 26 Javascript
javascript跨域的方法汇总
Oct 23 Javascript
jQuery Validate表单验证深入学习
Dec 18 Javascript
jQuery实现的动态文字变化输出效果示例【附演示与demo源码下载】
Mar 24 jQuery
移动端web滚动分页的实现方法
May 05 Javascript
vue组件实现文字居中对齐的方法
Aug 23 Javascript
Node.js实现连接mysql数据库功能示例
Sep 15 Javascript
JS实现移动端整屏滑动的实例代码
Nov 10 Javascript
利用vue+elementUI实现部分引入组件的方法详解
Nov 22 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
ThinkPHP类似AOP思想的参数验证的实现方法
2019/12/18 PHP
PHP文件打开关闭及读写操作示例解析
2020/08/06 PHP
javascript多种数据类型表格排序代码分析
2010/09/11 Javascript
Window.Open如何在同一个标签页打开
2014/06/20 Javascript
jquery获取选中的文本和值的方法
2014/07/08 Javascript
javascript实现控制div颜色
2015/07/07 Javascript
js实现用户离开页面前提示是否离开此页面的方法(包括浏览器按钮事件)
2015/07/18 Javascript
js检测iframe是否加载完成的方法
2015/11/26 Javascript
jQuery学习笔记——jqGrid的使用记录(实现分页、搜索功能)
2016/11/09 Javascript
JS常见算法详解
2017/02/28 Javascript
使用react-router4.0实现重定向和404功能的方法
2017/08/28 Javascript
Vue formData实现图片上传
2019/08/20 Javascript
HTML元素拖拽功能实现的完整实例
2020/12/04 Javascript
python中pass语句用法实例分析
2015/04/30 Python
Python 两个列表的差集、并集和交集实现代码
2016/09/21 Python
在Python中通过getattr获取对象引用的方法
2019/01/21 Python
Python的条件表达式和lambda表达式实例
2019/01/31 Python
python2和python3应该学哪个(python3.6与python3.7的选择)
2019/10/01 Python
在Tensorflow中实现梯度下降法更新参数值
2020/01/23 Python
Python实现爬取并分析电商评论
2020/06/19 Python
Python 实现微信自动回复的方法
2020/09/11 Python
纯css3实现鼠标经过图片显示描述的动画效果
2014/09/01 HTML / CSS
详解CSS 3 中的 calc() 方法
2018/01/12 HTML / CSS
Sandro法国官网:法国成衣品牌
2019/08/28 全球购物
大学四年个人自我小结
2014/03/05 职场文书
赡养老人协议书
2014/04/21 职场文书
羽毛球社团活动总结
2014/06/27 职场文书
银行委托书范本
2014/09/28 职场文书
2014年项目经理工作总结
2014/11/24 职场文书
清洁员岗位职责
2015/02/15 职场文书
我的中国梦主题教育活动总结
2015/05/07 职场文书
2016年小学生迎国庆广播稿
2015/12/18 职场文书
创业计划书之电动车企业
2019/10/11 职场文书
Python实现机器学习算法的分类
2021/06/03 Python
教你用Python matplotlib库制作简单的动画
2021/06/11 Python
科学家研发出新型速效酶,可在 24 小时内降解塑料制品
2022/04/29 数码科技