一个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 相关文章推荐
node.js 使用ejs模板引擎时后缀换成.html
Apr 22 Javascript
JS实现点击复选框将按钮或文本框变为灰色不可用的方法
Aug 11 Javascript
js实现的全国省市二级联动下拉选择菜单完整实例
Aug 17 Javascript
JavaScript实现向右伸出的多级网页菜单效果
Aug 25 Javascript
Bootstrap每天必学之表单
Nov 23 Javascript
js实现将选中内容分享到新浪或腾讯微博
Dec 16 Javascript
AngularJS模块学习之Anchor Scroll
Jan 19 Javascript
原生js开发的日历插件
Feb 04 Javascript
从零学习node.js之简易的网络爬虫(四)
Feb 22 Javascript
vue-cli中的webpack配置详解
Sep 25 Javascript
简单实现jquery隔行变色
Nov 09 jQuery
vue.js 实现点击按钮动态添加li的方法
Sep 07 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调用Oracle存储过程
2006/10/09 PHP
用PHP和ACCESS写聊天室(八)
2006/10/09 PHP
Linux下PHP安装mcrypt扩展模块笔记
2014/09/10 PHP
PHP实现手机号码中间四位用星号(*)隐藏的自定义函数分享
2014/09/27 PHP
PHP输入输出流学习笔记
2015/05/12 PHP
php微信公众号开发之微信企业付款给个人
2018/10/04 PHP
php创建多级目录与级联删除文件的方法示例
2019/09/12 PHP
使用PHP+Redis实现延迟任务,实现自动取消订单功能
2019/11/21 PHP
js鼠标滑轮滚动事件绑定的简单实例(兼容主流浏览器)
2014/01/14 Javascript
Js实现滚动变色的文字效果
2014/06/16 Javascript
简介JavaScript中setUTCSeconds()方法的使用
2015/06/12 Javascript
WEB前端实现裁剪上传图片功能
2016/10/17 Javascript
bootstrap快速制作后台界面
2016/12/05 Javascript
微信小程序 自定义消息提示框
2017/08/06 Javascript
Nodejs进阶之服务端字符编解码和乱码处理
2017/09/04 NodeJs
Vue.js分页组件实现:diVuePagination的使用详解
2018/01/10 Javascript
JS实现为动态添加的元素增加事件功能示例【基于事件委托】
2018/03/21 Javascript
微信小程序之多列表的显示和隐藏功能【附源码】
2018/08/06 Javascript
JS实现简单移动端鼠标拖拽
2020/07/23 Javascript
Element Input输入框的使用方法
2020/07/26 Javascript
python实现多线程采集的2个代码例子
2014/07/07 Python
Python处理JSON数据并生成条形图
2016/08/05 Python
Python实现可获取网易页面所有文本信息的网易网络爬虫功能示例
2018/01/15 Python
Jupyter notebook远程访问服务器的方法
2018/05/24 Python
Tensorflow设置显存自适应,显存比例的操作
2020/02/03 Python
Python中使用Selenium环境安装的方法步骤
2021/02/22 Python
日本最大的旅游网站:Rakuten Travel(乐天旅游)
2018/08/02 全球购物
在校生党员自我评价
2013/09/25 职场文书
优秀员工个人的自我评价
2013/11/29 职场文书
同事打架检讨书
2014/02/04 职场文书
诚信考试倡议书
2014/04/15 职场文书
小学生植树节活动总结
2014/07/04 职场文书
贷款承诺书
2015/01/20 职场文书
计算机专业自荐信
2015/03/05 职场文书
就业推荐表院系意见
2015/06/05 职场文书
科技馆观后感
2015/06/08 职场文书