ECMA6 ---- Class篇 (重难点个人向)

一、Class中的this指向问题

  • 构造函数中:this指向新创建出来的实例
  • 类的方法中:this指向该类的实例对象
  • 类的静态方法中:this指向类本身

二 、super的使用

1、super作为方法在子类的构造函数中使用

super表示父类的构造函数,子类的构造函数中super一定要放在构造函数最上面,因为super的作用是形成一个子类的对象,这个对象中包含了父类的实例属性和方法

2、super作为对象在子类的普通方法和静态方法中使用

  • 普通方法:super指向父类的原型对象,所以只能获取到父类原型对象中定义的属性和方法。实例对象上创建的属性和方法无法获取
  • 静态方法:super指向父类

如何辨别那些是原型对象中的属性和方法,那些是实例对象中的:除了显式定义在this上的,其他的的都是原型对象中的

三、类的继承关系

  • __proto__:在对象中,指向对应的构造函数的protoType属性,子类的__proto__属性,表示构造函数的继承,直接指向父类
  • protoType.__proto__:表示方法的继承,指向的是父类的protoType属性

父类和子类之间有两条继承链,一条是__proto__属性继承链,一条是protoType.__proto__属性继承链

核心

  • 实例的继承:通过super()调用父类构造函数设置获得
  • 原型方法及属性的继承:通过继承链children.protoType.__proto__ = parent.protoType获得
  • 静态方法:通过继承链children.__proto__ = parent获得

四、创建一个新实例时发生了什么事情

  1. 当调用 new Child() 时:

    • 先创建空对象 {}
    • 调用 Child 构造函数
    • Child 构造函数中调用 super()(即 Parent 构造函数)
    • Parent 构造函数向这个对象添加属性 ab
    • 然后 Child 构造函数继续添加属性 c
相关推荐
谢尔登3 小时前
【React Native】ScrollView 和 FlatList 组件
javascript·react native·react.js
然我3 小时前
面试官:如何判断元素是否出现过?我:三种哈希方法任你选
前端·javascript·算法
kk_stoper3 小时前
如何通过API查询实时能源期货价格
java·开发语言·javascript·数据结构·python·能源
晨枫阳4 小时前
前端VUE项目-day1
前端·javascript·vue.js
颜酱4 小时前
抽离ant-design后台的公共查询设置
前端·javascript·ant design
绅士玖4 小时前
JavaScript 设计模式之单例模式🚀
前端·javascript·设计模式
Dream耀4 小时前
useReducer:React界的"灭霸手套",一个dispatch搞定所有状态乱局
前端·javascript·react.js
余大侠在劈柴4 小时前
pdf.js 开发指南:在 Web 项目中集成 PDF 预览功能
前端·javascript·学习·pdf
拾光拾趣录5 小时前
JavaScript屏幕切换检测方案
前端·javascript
CodeTransfer5 小时前
搬运一个前端锻炼面向对象思维的小案例
前端·javascript