珊阡陌提 2023-02-09 15:53 采纳率: 30.3%
浏览 35
已结题

EventBus组件通信

EventBus组件通信,请问以下代码是什么意思


export class Bus {
  private static list: { [key: string]: Array<Function> } = {};

  public static $on(name: string, fn: Function) {
    this.list[name] = this.list[name] || [];
    this.list[name].push(fn);
  }

  public static $emit(name: string, data?: unknown) {
    if (this.list[name]) {
      this.list[name].forEach((fn: Function) => {
        fn(data);
      });
    }
  }

  public static $off(name: string) {
    if (this.list[name]) Reflect.deleteProperty(this.list, name);
  }
}
  • 写回答

2条回答 默认 最新

  • 成茂峰 2023-02-09 16:38
    关注

    理解为list是一个bus公交车
    $on是公交乘务员,监听:上车人员(name),还有刷卡(fn)
    $emit是人员上车,做的操作是刷卡(fn),带了data

    $on负责监听了$emit对应的人员(name)数据变化,进行后续fn操作

    $off 就是人到站了,下车了

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月18日
  • 已采纳回答 2月10日
  • 创建了问题 2月9日

悬赏问题

  • ¥15 运动想象脑电信号数据集.vhdr
  • ¥15 三因素重复测量数据R语句编写,不存在交互作用
  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目