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
相关推荐
Highcharts.js2 小时前
无需搭建数据管道,如何快速上线投资基金筛选器?
开发语言·javascript·react.js·前端框架·highcharts
kyriewen2 小时前
我让AI替我写Git提交信息,老板以为我每天工作16小时
前端·javascript·git
接着奏乐接着舞2 小时前
react native expo打包
javascript·react native·react.js
chushiyunen2 小时前
typescript笔记、ts笔记、npx命令
javascript·笔记·typescript
ZC跨境爬虫3 小时前
跟着 MDN 学 HTML day_55:HTML 音频与视频嵌入实战指南
前端·javascript·ui·html·音视频·媒体
m0_502724953 小时前
golang 、java、c++、javascript 语言switch case异同
java·javascript·c++·golang
ZC跨境爬虫4 小时前
跟着 MDN 学 HTML day_57:(HTML 表格进阶特性与无障碍实践)
java·前端·javascript·ui·html·音视频
Moment4 小时前
刷 Reddit 1 小时没结果?我用这个方法 10 秒挖出真实需求
前端·javascript·后端
w_t_y_y4 小时前
VUE组件配置项(零)概述
前端·javascript·vue.js