super的使用

1、继承而来的类 constructor 方法中的this必须在super之后

2、例1的代码会报错,因为VideoIntercomDevice 调用了super但是super没有传参,是个undefined,undefined去结构就会报错的,纠正的话改为 super({})

3、那我好奇,到底super复制的属性级别更高,还是子类中this指定的值等级更高,见例2,结论:无所谓级别高低,会覆盖掉

例1:

javascript 复制代码
class Config {
  constructor() {
    console.log('Config调用')
    this.id = 0;
  }
}
class AccessDevice extends Config {
  constructor({ id, isCsJump }) {
    console.log('AccessDevice')
    super();
    this.id = id;
    this.isCsJump = isCsJump;
  }
}
class VideoIntercomDevice extends AccessDevice {
  constructor({ id, isCsJump }) {
    console.log('1', id, isCsJump)
    super()
    console.log('id', id)
    this.id = 9;
    this.isCsJump = isCsJump;
  }
}
let ad = new VideoIntercomDevice({id: 1,isCsJump: true})
console.log(ad)

// 最终会打印:1 1 true
相关推荐
晴殇i几秒前
🎉 TRAE 一年使用的过程体验 🎉
前端
GDAL5 分钟前
Tailwind CSS Flex 布局深入全面教程
前端·css·tailwindcss
qq. 28040339848 分钟前
react --> redux
前端·react.js·前端框架
前端不太难10 分钟前
用 RN 的渲染模型,反推 Vue 列表的正确拆分方式
前端·javascript·vue.js
JS_GGbond16 分钟前
防抖与节流:前端性能优化“双剑客”
前端
KLW7520 分钟前
vue v-if和v-show比较
前端·css·css3
梵尔纳多25 分钟前
使用 Electron 实现一个简单的文本编辑器
前端·javascript·electron
晴殇i27 分钟前
SPA首屏加载速度优化!
前端
ts97727 分钟前
Nginx + Vue History 模式刷新 404 的完整排查与解决方案
运维·vue.js·nginx
qq. 280403398428 分钟前
react 副作用探究
前端·react.js