js的6种继承

js的6种继承

原型链(类式)继承

  • 让新实例的原型等于父类的实例。

构造函数继承

  • 用.call()和.apply()将父类构造函数引入子类函数
  • 优点
    • 只继承了父类构造函数的属性,没有继承父类原型的属性。

组合继承

  • 结合了两种模式的优点,传参和复用

原型式继承

  • 用一个函数包装一个对象,然后返回这个函数的调用,这个函数就变成了个可以随意增添属性的实例或对象。object.create()就是这个原理。

寄生继承

  • 就是给原型式继承外面套了个壳子。

寄生组合继承

  • 修复了组合继承的问题
// 1.原型链(类式)继承
/*重点:让新实例的原型等于父类的实例。
    特点:1、实例可继承的属性有:实例的构造函数的属性,父类构造函数属性,父类原型的属性。(新实例不会继承父类实例的属性!)
    缺点:1、新实例无法向父类构造函数传参。
       2、继承单一。
       3、所有新实例都会共享父类实例的属性。(原型上的属性是共享的,一个实例修改了原型属性,另一个实例的原型属性也会被修改!)*/
//  function Book(){
//    this.name='book'
//
//  }
//  Book.prototype.price='12';
//
//  function BookChildren(){
//    this.age=12;
//    this.name='1111'
//  }
//  BookChildren.prototype=new Book();
//
//  let bookC=new BookChildren();
// console.log(bookC)
//
// console.log(bookC.price)

// 2.构造函数继承
/*
* 重点:用.call()和.apply()将父类构造函数引入子类函数(在子类函数中做了父类函数的自执行(复制))
    特点:1、只继承了父类构造函数的属性,没有继承父类原型的属性。
       2、解决了原型链继承缺点1、2、3。
       3、可以继承多个构造函数属性(call多个)。
       4、在子实例中可向父实例传参。
    缺点:1、只能继承父类构造函数的属性。
       2、无法实现构造函数的复用。(每次用每次都要重新调用)
       3、每个新实例都有父类构造函数的副本,臃肿。

* */
// function Book(name){
//   this.name=name
//
// }
// Book.prototype.price='12';
// function BookChildren(name,age){
//   Book.call(this,name) //Book()  this.name = name;
//   this.age=age;
// }
// let bookC=new BookChildren('jsbook','12');
// console.log(bookC)


// 3. 组合继承
/*重点:结合了两种模式的优点,传参和复用
    特点:1、可以继承父类原型上的属性,可以传参,可复用。
       2、每个新实例引入的构造函数属性是私有的。
    缺点:调用了两次父类构造函数(耗内存),子类的构造函数会代替原型上的那个父类构造函数。
*/
// function Book(name){
//   this.name=name
//
// }
// Book.prototype.price='12';
// function BookChildren(name,age){
//   Book.call(this,name)
//   this.age=age;
// }
// BookChildren.prototype=new Book();
// let bookC=new BookChildren('jsbook','12');
// console.log(bookC)

// 4. 原型式继承
/*   重点:用一个函数包装一个对象,然后返回这个函数的调用,这个函数就变成了个可以随意增添属性的实例或对象。object.create()就是这个原理。
    特点:类似于复制一个对象,用函数来包装。
    缺点:1、所有实例都会继承原型上的属性。
       2、无法实现复用。(新实例属性都是后面添加的)
*/
/*function inheritObject(obj){
  function F(){};
  F.prototype=obj;
  return new F();

}
let bookC=inheritObject({name:'book',price:'12'});
console.log(bookC)*/

// 5.寄生继承
/* 重点:就是给原型式继承外面套了个壳子。
    优点:没有创建自定义类型,因为只是套了个壳子返回对象(这个),这个函数顺理成章就成了创建的新对象。
    缺点:没用到原型,无法复用。
* */
function inheritObject(obj){
  function F(){};
  F.prototype=obj;
  return new F();

}
function creatPrototype(obj){
  let o=inheritObject(obj);
  o.grade='12grade';
  return o;

}
let bookC =creatPrototype({name:'book',price:'12'});
console.log(bookC.price)

// 6.寄生组合继承
//重点:修复了组合继承的问题

function inheritPrototype(Target,Origin){
  function F(){};
  F.prototype=Origin.prototype;

  Target.prototype= new F();
  Target.prototype.constructor=Target;
    Target.prototype.sub=Origin;
}
function Book(name){
  this.name=name
}
Book.prototype={
  price:'12'
}
function BookChildren(name,num){
  Book.call(this,name);
  this.num=num;

}
inheritPrototype(BookChildren,Book)
let bookC =new BookChildren('jsBook','24本')
console.log(bookC.sub)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值