js es6 class 类中的值是异步赋值, 子类中如何获取这个值?

在 ES6 类中,如果父类的属性是通过异步赋值 的,子类能否获取到这个值取决于访问时机。下面通过代码示例详细说明:

1. 同步 vs 异步赋值的区别

同步赋值(正常情况)

javascript 复制代码
class Parent {
  constructor() {
    this.syncValue = '同步值'; // 同步赋值
  }
}

class Child extends Parent {
  getValues() {
    return {
      syncValue: this.syncValue // 可以正常获取
    };
  }
}

const child = new Child();
console.log(child.getValues()); // { syncValue: '同步值' }

异步赋值的情况

javascript 复制代码
class Parent {
  constructor() {
    this.asyncValue = null;
    // 异步赋值
    setTimeout(() => {
      this.asyncValue = '异步赋值完成';
    }, 1000);
  }
}

class Child extends Parent {
  getValues() {
    return {
      asyncValue: this.asyncValue // ❌ 立即访问可能为 null
    };
  }
}

const child = new Child();
console.log(child.getValues()); // { asyncValue: null }

// 1秒后再访问
setTimeout(() => {
  console.log(child.getValues()); // { asyncValue: '异步赋值完成' }
}, 1500);

2. 解决方案

点击查看解决方案

总结

  • 子类可以获取父类的异步赋值 ,但必须在异步操作完成后
  • 立即访问可能得到 null 或初始值
  • 推荐使用 Promiseasync/await 来管理异步状态
  • 通过等待初始化完成的方法确保数据可用性
  • 事件监听模式适合需要实时响应的场景

关键在于时序控制 - 确保在访问异步值之前,相关的异步操作已经完成。

相关推荐
Daniel李华5 小时前
echarts使用案例
android·javascript·echarts
北原_春希5 小时前
如何在Vue3项目中引入并使用Echarts图表
前端·javascript·echarts
JY-HPS5 小时前
echarts天气折线图
javascript·vue.js·echarts
尽意啊5 小时前
echarts树图动态添加子节点
前端·javascript·echarts
吃面必吃蒜5 小时前
echarts 极坐标柱状图 如何定义柱子颜色
前端·javascript·echarts
O_oStayPositive5 小时前
Vue3使用ECharts
前端·javascript·echarts
竹秋…5 小时前
echarts自定义tooltip中的内容
前端·javascript·echarts
宝贝露.5 小时前
Axure引入Echarts图无法正常显示问题
前端·javascript·echarts
人良爱编程5 小时前
Hugo的Stack主题配置记录03-背景虚化-导航栏-Apache ECharts创建地图
前端·javascript·apache·echarts·css3·html5
来颗仙人掌吃吃5 小时前
解决Echarts设置宽度为100%发现宽度变为100px的问题(Echarts图标宽度自适应问题)
前端·javascript·echarts