欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2023-11-27 08:56:40
组合继承有时候也叫伪经典继承,指的是将原型链和借用构造函数技术组合到一块,从而发挥二者之长的一种继承模式,其背后的思路是使用原型链实现对原型属性和方法的继承,而通过借用构造...

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

 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;
 }
 subtype.prototype=new supertype();
 subtype.prototype.constructor=subtype;
 subtype.prototype.sayage=function(){
  console.log(this.age);
 }
 var instance1=new subtype("zxf",24);
 instance1.colors.push("black");
 console.log(instance1.colors);//["red","blue","green","black"]
 instance1.sayname();//"zxf"
 instance1.sayage();//24
 var instance2=new subtype("jay",36);
 console.log(instance2.colors);//["red","blue","green"]
 instance2.sayname();//"jay"
 instance2.sayage();//36

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

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

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

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