ES5中继承的方法:
1.原型链继承 2.借用构造函数继承 3.组合继承 4.原型继承 5.寄生式继承 6.寄生组合式继承
组合继承=原型继承+构造函数继承
原型继承:子类原型prototype对父类实例化来实现
优点:子类不仅仅可以访问父类原型上的属性和方法,同样也可以访问从父类构造函数中复制的属性和方法
缺点:一个子类原型更改子类原型从父类继承来的引用类型属性就会直接影响其他子类(一个子类改变,其他子类都改变)
构造函数继承:在子类构造函数作用环境执行一次父类的构造函数实现
优点:避免了引用类型的属性被所有实例共享,而且可以在子类中向父类传参
缺点:这种类型的继承没有涉及原型prototype,所以父类的原型方法自然不会被子类继承;
而要想被子类继承就必须把放在构造函数里,这样创建出来的每个实例都会单独拥有一份而不能共用,这样就违背了代 码复用的原则
//构造函数
function Supert(name) {
this.name =name;
// this.colors = ["red", "blue", "yellow"];
}
Supert.prototype.colors=["red", "blue", "yellow"];
Supert.prototype.getName=function(){
console.log(this.name)
}
function Supert2(name){
Supert.call(this,name)
}
//原型继承
Supert2.prototype=new Supert()
let ans=new Supert2("姓名");
console.log(ans.name)
ans.getName()