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
相关推荐
左耳咚5 小时前
项目开发中从补码到精度丢失的陷阱
前端·javascript·面试
D_C_tyu6 小时前
Vue3 + Element Plus 实现前端手动分页
javascript·vue.js·elementui
黑云压城After6 小时前
vue2实现图片自定义裁剪功能(uniapp)
java·前端·javascript
用户47949283569158 小时前
从 58MB 到 2.6MB:我是如何将 React 官网性能提升 95% 的
前端·javascript
该用户已不存在8 小时前
7个让全栈开发效率起飞的 Bun 工作流
前端·javascript·后端
芙蓉王真的好18 小时前
Angular CDK 响应式工具指南:从基础到自适应布局应用
前端·javascript·angular.js
明仔的阳光午后9 小时前
React 入门 01:快速写一个React的HelloWorld项目
前端·javascript·react.js·前端框架·reactjs·react
橙某人10 小时前
Vue3 + Pinia 移动端Web应用:页面缓存策略解决方案💡
前端·javascript·vue.js
San3011 小时前
使用 OpenAI API 生成文本与图片:从环境搭建到提示工程完全解析
javascript·人工智能·node.js
TimelessHaze11 小时前
🚀 一文吃透 React 性能优化三剑客:useCallback、useMemo 与 React.memo
前端·javascript·react.js