js常用的继承——组合式继承

  

组合继承有时候也叫伪经典继承,指的是将原型链和借用构造函数技术组合到一块,从而发挥二者之长的一种继承模式,其背后的思路是使用原型链实现对原型属性和方法的继承,而通过借用构造函数来实现对实例属性的继承。这样既通过在原型上定义方法实现了函数复用,又能保证每个实例都有它的自己的属性。

        函数的超类型(名字){   this.name=名称;   this.colors=(“红”、“蓝”、“绿色”);   }   SuperType.prototype.sayName=function () {   console.log (this.name);   }   函数亚型(姓名、年龄){   SuperType.call(这名字);   this.age=年龄;   }   亚型。原型=new超类型();   SubType.prototype.constructor=亚型;   SubType.prototype.sayAge=function () {   console.log (this.age);   }   var instance1=new亚型(“zxf”, 24);   instance1.colors.push(“黑色”);   console.log (instance1.colors);//(“红”“蓝”、“绿色”、“黑色”)//皕xf instance1.sayName ();   instance1.sayAge ();//24   var instance2=new亚型(“周杰伦”,36);   console.log (instance2.colors);//(“红”“蓝”,“绿色”)   instance2.sayName();//爸芙苈住?   instance2.sayAge ();//36      

在这个例子中,超类型构造函数定义了两个属性,名字和colors.supertype的原型定义了一个方法sayname () .subtype构造函数调用超类型时传入了名字参数,紧接着又定义了它自己的属性的年龄,然后将超类型的实例赋值给亚型的原型,然后又在该新原型上定义了方法sayage()。这样一来,就可以让两个不同的亚型实例既可以拥有属性,包括颜色属性,又可以使用相同的方法。

  

组合式继承缺点是:调用了两次超类型构造函数,一次在赋值子类型的原型时,一次在实例化子类时调用调用,这次调用会屏蔽原型中的两个同名属性。

  

参考书籍:Javascript高级程序设计(第3版),

  

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!

js常用的继承——组合式继承