作家
登录

再论Javascript的类继承

作者: 来源:www.28hudong.com 2013-03-30 00:58:09 阅读 我要评论

无参数类继承的问题 先看一段示例代码,实现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的一个扩展,迟些发布。

  推荐阅读

  始终在屏幕中间显示Div的代码(css+js)

一、在中间显示;(参考:sky100articles1790515) 复制代码 代码如下: .ordersearchDivCss { position: absolute; z-index: 100; display: block; background-color: #6ec1df; } <div class="ordersearchDivCss" id=>>>详细阅读


本文标题:再论Javascript的类继承

地址:http://www.17bianji.com/kaifa2/JS/24831.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)