博客
关于我
ES6之class的继承
阅读量:194 次
发布时间:2019-02-28

本文共 882 字,大约阅读时间需要 2 分钟。

ES6类继承理解与实践——Man类详解

在前端开发中,理解类继承的机制是至关重要的。ES6引入了extends关键字,使类继承变得更加清晰和方便,这与传统的通过修改原型链实现继承相比,具有显著优势。

以下是一个典型的例子,展示了如何使用extends实现类继承:

class Human {  constructor(name) {    this.name = name;  }  run(mile) {    console.log(`我每小时能跑${mile}`);  }  static hello() {    console.log('hello world');  }}class Man extends Human {  constructor(name, age) {    super(name); // 必须先调用父类构造函数    this.age = age;  }}const man = new Man('小王', 22);console.log(man.name); // 小王console.log(man.age); // 22man.run(111); // 我每小时能跑111man.hello(); // hello world

注意以下关键点:

  • 子类构造函数的处理:在子类的构造函数中,必须先调用super(),否则会抛出ReferenceError。这是因为子类实例的构建依赖于父类实例的构建,super()方法才能调用父类构造函数。

  • 静态方法的继承:子类可以继承父类的静态方法。例如,Man.hello()可以直接调用Human.hello()的功能。

  • 属性的访问顺序:在子类实例中,this对象的属性和方法的初始化顺序是:先父类的属性被初始化,再执行子类的逻辑。

  • 这种实现方式相比传统的原型链继承,代码更加清晰,逻辑更加明确。通过合理使用extends,我们可以更方便地扩展和维护类的代码结构。

    如果你对前端开发感兴趣,欢迎加入我们的技术交流QQ群:327814892,和志同道合的朋友一起探讨更多有趣的技术内容!

    转载地址:http://utri.baihongyu.com/

    你可能感兴趣的文章
    Oracle创建database link(dblink)和同义词(synonym)
    查看>>
    oracle创建数据库的步骤
    查看>>
    Oracle创建用户、角色、授权、建表
    查看>>
    Oracle创建用户与授予表空间与权限
    查看>>
    oracle创建表(并且实现ID自增)
    查看>>
    oracle删除重复数据保留第一条记录
    查看>>
    oracle判断空值的函数nvl2,【PL/SQL】 NVL,NVL2,COALESCE 三种空值判断函数
    查看>>
    Oracle发布VirtualBox 7.1稳定版!支持ARM、优化了UI、支持Wayland等
    查看>>
    oracle启动三步
    查看>>
    oracle启动关闭服务,启动关闭oracle服务.bat
    查看>>
    Oracle命令行创建数据库
    查看>>
    Oracle和SQL server的数据类型比较
    查看>>
    oracle和sybase的一些区别
    查看>>
    oracle在日本遇到的技术问题
    查看>>
    Oracle在线重定义
    查看>>
    oracle基础 管理索引
    查看>>
    Oracle增量跟新
    查看>>
    oracle复习(一)
    查看>>
    ORACLE多表关联UPDATE 语句
    查看>>
    Oracle多表查询与数据更新
    查看>>