当前位置:Gxlcms > JavaScript > JavaScript实现多重继承实例详解

JavaScript实现多重继承实例详解

时间:2021-07-01 10:21:17 帮助过:33人阅读

本文主要介绍了JavaScript实现多重继承的方法,结合实例形式详细分析了javascript实现多重继承的具体步骤与相关操作技巧,需要的朋友可以参考下,希望能帮助到大家。

1. 定义一个空的父类构造函数,然后通过prototype的方式为该父类定义属性和方法

2. 定义一个空的子类的构造函数,然后将子类的原型绑定在父类的实例上,再将子类原型的父类也绑定在父类的实例上。通过prototype的方式为子类设置自己的属性和方法。

3. 定义一个空的孙类构造函数,然后将孙类的原型绑定到子类的实例上,再将孙类原型的父类绑定到子类的实例上。通过prototype方式为孙类定义自己的属性和方法。

4. 实例化一个孙类对象,通过调用该实例对象,调用自身的方法,也可以调用孙类的父类即文中的子类的方法,也可直接调用最大父类即这里父类的方法,也可以为当前对象添加属性和方法。


输出:我是Child类的say方法! c.superClass.say(); // 调用父类Parent的say方法,输出: 我是Parent类的say方法! c.superClass.superClass.say("哈哈");// 直接调用最大的父类Person的say方法(方法中的this指向Person),输出:我是人,我想说哈哈" // 用call调用最大的父类Person的say方法(方法中的this指向实例化对象c,但此时c并没有name属性,所以this.name用的是Parent的name) c.superClass.superClass.say.call(c,"嘻嘻"); // 输出:我是父辈类,我想说嘻嘻 c.name = "子类实例";// 给当前对象增加name属性 // 还是用call调用最大父类Person的say方法(此时c对象中已经有name属性); c.superClass.superClass.say.call(c,"我是子类的实例化对象"); // 输出:我是子类实例,我想说我是子类的实例化对象

ps:多重继承可以在原型对象上新增一个属性用以保存父类的对象和属性,子类调用的时候使用superClass点出父类方法,这样一来就解决了父类和子类方法同名,子类继承父类之后会覆盖父类方法的问题。

相关推荐:

深入分析python的多重继承

关于实现多重继承的10篇文章推荐

PHP面向对象之多重继承与接口用法

以上就是JavaScript实现多重继承实例详解的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行