JavaScript常见的继承方式

作者 : 开心源码 本文共1817个字,预计阅读时间需要5分钟 发布时间: 2022-05-12 共238人阅读

前言

JS作为面向对象的弱类型语言,继承也是其非常强大的特性之一。那么在JS中常见的继承方式有几种呢?

方式一、原型链继承

  1. 套路
    • 定义父类型构造函数
    • 给父类型的原型增加方法
    • 定义子类型的构造函数
    • 创立父类型的对象赋值给子类型的原型
    • 将子类型原型的构造属性设置为子类型
    • 给子类型原型增加方法
    • 创立子类型的对象: 可以调用父类型的方法
  2. 关键在于:子类型的原型为父类型的一个实例对象
//父类型 function Supper() {   this.supProp = 'Supper property' } Supper.prototype.showSupperProp = function () {   console.log(this.supProp) } //子类型 function Sub() {   this.subProp = 'Sub property' } // 子类型的原型为父类型的一个实例对象 Sub.prototype = new Supper() // 让子类型的原型的constructor指向子类型 Sub.prototype.constructor = Sub Sub.prototype.showSubProp = function () {   console.log(this.subProp) } var sub = new Sub() sub.showSupperProp()//Supper property sub.showSubProp()//Sub property

特点

  • 父类新添加原型方法/原型属性,子类都能访问到
  • 简单,易于实现

缺点

  • 要想为子类新添加属性和方法,必需要在new Supper()这样的语句之后执行,不能放到构造器中
  • 无法实现多继承
  • 来自原型对象的所有属性被所有实例共享
  • 创立子类实例时,无法向父类构造函数传参

方式二: 借用构造函数继承

  1. 套路:
    • 定义父类型构造函数
    • 定义子类型构造函数
    • 在子类型构造函数中调用父类型构造
  2. 关键在于:在子类型构造函数中通用call()调用父类型构造函数
<script type="text/javascript">  function Person(name, age) {    this.name = name    this.age = age  }  function Student(name, age, price) {    Person.call(this, name, age)  // 相当于: this.Person(name, age)    /*this.name = name    this.age = age*/    this.price = price  }  console.log(s.name, s.age, s.price)//Tom 20 14000  var s = new Student('Tom', 20, 14000)

特点

  • 处理了原型链继承中子类实例共享父类引用属性的问题
  • 创立子类实例时,可以向父类传递参数
  • 可以实现多继承(call多个父类对象)

缺点

  • 实例并不是父类的实例,只是子类的实例
  • 只能继承父类的实例属性和方法,不能继承原型属性/方法
  • 无法实现函数复用,每个子类都有父类实例函数的副本,影响性能

方式三: 原型链+借用构造函数的组合继承

  1. 利用原型链实现对父类型对象的方法继承
  2. 利用super()借用父类型构建函数初始化相同属性
 function Person(name, age) {    this.name = name    this.age = age  }  Person.prototype.setName = function (name) {    this.name = name  }  function Student(name, age, price) {    Person.call(this, name, age)  // 为了得到属性    this.price = price  }  Student.prototype = new Person() // 为了能看到父类型的方法  Student.prototype.constructor = Student //修正constructor属性  Student.prototype.setPrice = function (price) {    this.price = price  }  var s = new Student('Tom', 24, 15000)  s.setName('Bob')  s.setPrice(16000)  console.log(s.name, s.age, s.price)//Bob 24 16000

优点:融合原型链继承和构造函数的优点,是 JavaScript 中最常用的继承模式。

参考文章

JS实现继承的几种方式

JavaScript深入之继承的多种方式和优缺点

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » JavaScript常见的继承方式

发表回复