ES5中的继承(组合继承)

  ES6中类的继承使用extends关键字,那么ES5中是怎么实现的呢?javascript

  ES5中采用构造函数和原型对象的组合方式模拟继承,因此也称为组合继承;java

  核心原理:经过call()借用父构造函数,并把父类型的this指向子类型的this;函数

  这种继承,其实是在调用子构造函数建立实例对象时,在子构造函数内调用了父构造函数,那么就能够得到父构造函数中的成员,同时修改被调用的父构造函数的this的指向为子函数便可,成员就会被继承到子函数中;this

  用一句话说:使用call()在子构造函数调用父构造函数,实现继承;记得修改父构造函数中的this为子函数中的thisspa

function Father(uname, age){
  this.uname = uame;
  this.age = age;        
}
function Son(uname, age){
  Father.call(this);
}

  借用原型对象继承方法prototype

Son.prototype = new father();//由于能够经过原型链访问到Father的原型对象中的方法
Son.prototype.constructor = Son;//上面的赋值操做,会使Son的constructor指向Father
相关文章
相关标签/搜索