时间:2021-05-26
本文实例讲述了JavaScript寄生组合式继承。分享给大家供大家参考,具体如下:
寄生组合式继承
寄生组合式继承,就是通过伪造对象来继承属性,通过原型链的混成形式来继承方法。
这种技术的基本思路是:不必为了指定子类型的原型而调用超类型的构造函数,因为我们所需要的只是超类型原型的一个副本而已(这一点正是组合继承的问题,并且正是JavaScript这种原型式语言的强大之处,直接copy对象-原型对象)。本质上,就是使用寄生式继承来继承超类型的原型,然后再将结果指定给子类型的原型。
function inheritPrototype(subType, superType){ var prototype = Object.create(superType.prototype); //创建超类型原型副本 prototype.constructor = subType; //修改原型副本的不同属性 subType.prototype = prototype; //指定原型}function SuperType(name){ this.name = name; this.colors = ["red", "blue", "green"];}SuperType.prototype.sayName = function(){ console.log(this.name);}function SubType(name, age){ //继承属性 SuperType.call(this, name); //实例属性 this.age = age;}//继承方法inheritPrototype(SubType, SuperType);SubType.prototype.sayAge = function(){ console.log(this.age);};var instance1 = new SubType("Nicholas", 29);instance1.colors.push("black");console.log(instance1.colors); //"red, blue, green, black"instance1.sayName(); //"Nicholas"instance1.sayAge(); //29这里使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码,可得如下运行结果:
这个是寄生组合式继承的最简单形式。这个函数接收两个参数:
1. 子类型构造函数
2. 超类型构造函数
在函数内部,寄生组合式继承最简形式分为3个步骤:
1. 创建超类型原型副本;
2. 为创建的副本指定constructor属性,从而弥补因为重写SubType原型而失去的默认的constructor属性,这个原型副本的constructor属性变化:SuperType –> SubType;
3. 将该完善好的副本赋值给子类型的原型。
寄生组合式继承的图解如下:
寄生组合式继承的高效率体现在它只调用了一次SuperType构造函数,并且因此避免了在SubType.prototype上面创建不必要的,多余的属性。与此同时,原型链还能保持不变。
更多关于JavaScript相关内容还可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
javascript中的继承实例详解阅读目录原型链继承借用构造函数组合继承寄生组合式继承后记继承有两种方式:接口继承和实现继承。接口继承只继承方法签名,而实现继
这一次要讲组合、原型式、寄生式、寄生组合式继承方式。1.组合继承:又叫伪经典继承,是指将原型链和借用构造函数技术组合在一块的一种继承方式。下面来看一个例子:fu
本文实例讲述了JavaScript寄生组合式继承。分享给大家供大家参考,具体如下:其实《JavaScript高级程序设计》这本书中已经有完整代码了,只要把代码读
组合式淘宝流量的迸发,精准人群标签、以小搏大的高投产打造单品爆款。组合式淘宝流量分为付费淘宝流量与免费淘宝流量,淘宝流量占比28组合即为最合理,付费淘宝流量最常
在之前javascript面向对象系列的文章里面,我们已经探讨了组合继承和寄生继承,回顾下组合继承:functionPerson(uName){this.ski