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
相关推荐
米诺zuo几秒前
Angular 18 核心特性速查表
前端
源猿人1 分钟前
前端批量请求的并发控制与工程化实践
javascript
hey_ner1 分钟前
进度条图表简单化
前端·css·css3
苏西的网络日志3 分钟前
前端项目缓存控制与自动版本检查方案实现
前端
小遁哥10 分钟前
通过AI从零开发RN到在安卓手机上运行
前端·react native·cursor
sure28213 分钟前
react native中实现视频转歌
前端·react native
weipt18 分钟前
关于vue项目中cesium的地图显示问题
前端·javascript·vue.js·cesium·卫星影像·地形
FanetheDivine19 分钟前
图片标注框选组件
前端·react.js
懒大王、19 分钟前
Vue3 + OpenSeadragon 实现 MRXS 病理切片图像预览
前端·javascript·vue.js·openseadragon·mrxs
SoaringHeart20 分钟前
Flutter最佳实践:路由弹窗终极版NSlidePopupRoute
前端·flutter