博客
关于我
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/

    你可能感兴趣的文章
    POI解析Excel【poi的坑——空行处理】
    查看>>
    POI:POI+JXL实现xls文件添加水印
    查看>>
    POI:POI实现docx文件添加水印
    查看>>
    POJ 1006
    查看>>
    Quartz中时间表达式的设置-----corn表达式
    查看>>
    poj 1035
    查看>>
    POJ 1061 青蛙的约会 (扩展欧几里得)
    查看>>
    Quartz2.2.1简单使用
    查看>>
    POJ 1080 Human Gene Functions(DP:LCS)
    查看>>
    Quant 开源项目教程
    查看>>
    POJ 1088 滑雪
    查看>>
    POJ 1095 Trees Made to Order
    查看>>
    POJ 1113 Wall(计算几何--凸包的周长)
    查看>>
    poj 1125Stockbroker Grapevine(最短路)
    查看>>
    Qualitor processVariavel.php 未授权命令注入漏洞复现(CVE-2023-47253)
    查看>>
    poj 1151 (未完成) 扫描线 线段树 离散化
    查看>>
    POJ 1151 / HDU 1542 Atlantis 线段树求矩形面积并
    查看>>
    poj 1163 数塔
    查看>>
    POJ 1177 Picture(线段树:扫描线求轮廓周长)
    查看>>
    Qualitor checkAcesso.php 任意文件上传漏洞复现(CVE-2024-44849)
    查看>>