再论Javascript的类继承

作者:heero 来源:heero博客 时间:2010-06-26 12:48:00 

说到Javascript的类继承,就必然离不开原型链,但只通过原型链实现的继承有着不少缺陷。

无参数类继承的问题

先看一段示例代码,实现B继承于A:

function A() {
}
A.prototype.a1 = function() {
};

function B() {
}
B.prototype = new A();
B.prototype.b1 = function() {
};

var b = new B();
alert(b.constructor == A); // true
alert(b.constructor == B); // false

这段代码的主要问题是:

  • 需要实例化A作为B的原型,此时就执行了A的构造函数。但按照面向对象的规则,实例化B之前,B及其父类A的构造函数都不应该执行

  • 更改了B的prototype,导致b.constructor不是B而是A

有参类继承的问题

假设A和B都有两个字符串参数s1和s2,A中计算了两段字符串的总长度,B直接以s1、s2为参数调用A:

function A(s1, s2) {
  this.totalLength = s1.length + s2.length;
}
A.prototype.a1 = function() {  
};

function B(s1, s2) {
}
B.prototype = new A();
B.prototype.b1 = function() {
};

new B("ab", "123");

可以看到,这段代码中根本没有办法把s1和s2传到A,而又因为实例化A作为B的原型时没有参数,所以出现了异常:

s1 is undefined

解决方案

s1和s2的作用域只在B内,要把它们传到A,就只能在B中操作,借助函数的apply方法就可以实现之:

function B(s1, s2) {
  A.apply(this, arguments);
  alert(this.totalLength);
}

接下来的问题就是如何把A的方法添加到B的原型中去。这也不难,只要遍历A.prototype,把方法复制到B.prototype即可。要注意的是,对于同名的方法,自然是子类优先(重载),因而不能覆盖:

for (var m in A.prototype) {
  if (!B.prototype[m]) {  // 父类不能覆盖子类的方法
    B.prototype[m] = A.prototype[m];
  }
}

后记

考虑到C#、Java等高级语言都抛弃了多继承,因此,本文所讨论的也只是单继承的情况。而本文所述的继承方法,也会写成jRaiser的一个扩展,迟些发布。

标签:类,继承,javascript
0
投稿

猜你喜欢

  • 使用Python监控文件内容变化代码实例

    2021-06-05 22:45:19
  • python字符串的一些常见实用操作

    2022-05-08 15:53:30
  • Django权限机制实现代码详解

    2022-09-18 01:21:51
  • python列表的常用操作方法小结

    2023-06-21 16:14:34
  • Vue实现自定义视频和图片上传的示例代码

    2024-05-21 10:30:21
  • .Net Core服务治理Consul使用服务发现

    2023-06-25 07:49:19
  • python k-近邻算法实例分享

    2022-03-26 14:47:17
  • Python解决两个整数相除只得到整数部分的实例

    2021-12-29 23:29:21
  • Python检测网络延迟的代码

    2023-03-26 08:36:31
  • AJAX实现web页面中级联菜单的设计

    2007-09-26 13:37:00
  • 使用Numpy打乱数组或打乱矩阵行

    2022-09-18 09:40:10
  • 提高JavaScript执行效率的23个实用技巧

    2023-08-15 18:38:12
  • Python生成器generator原理及用法解析

    2021-10-14 14:00:13
  • 详解MindSpore自定义模型损失函数

    2022-07-24 09:41:34
  • 详解Python中Pyyaml模块的使用

    2021-08-19 08:18:23
  • python3实现从kafka获取数据,并解析为json格式,写入到mysql中

    2023-06-12 21:30:21
  • 如何使用Idea进行合并代码分支

    2022-10-21 18:29:58
  • Microsoft SQL Server 2000安装问题集锦

    2008-12-10 14:26:00
  • django admin添加数据自动记录user到表中的实现方法

    2022-11-17 14:58:24
  • 用python实现超强的加密软件

    2022-12-06 11:42:50
  • asp之家 网络编程 m.aspxhome.com