鸿蒙:使用Emitter进行线程间通信

前言:

官方文档上说,Emitter是一种作用在进程内的事件处理机制,为应用程序提供订阅事件、发布事件、取消事件订阅的能力。

我们学习这个工具之前,还是老样子,照着官方文档和示例学习与实践,文档链接如下:

文档中心https://developer.huawei.com/consumer/cn/doc/harmonyos-guides/itc-with-emitter如果您看完了,但还有点迷糊,不妨看看我是怎么封装这个工具的。

下面是我运行的实际效果图和封装后的代码:

Index.ets

复制代码
import { emitterUtil } from "./EmitterUtil"

// emitter使用示例
@Entry
@Component
export struct Index {
  build() {
    Column({ space: 20 }) {
      Button("emitter.fire")
        .onClick(() => {
          emitterUtil.fire()

        })

      Button("emitter.on")
        .onClick(() => {
          emitterUtil.on()

        })

      Button("emitter.off")
        .onClick(() => {
          emitterUtil.off()

        })
    }
    .width("100%")
    .height("100%")
    .justifyContent(FlexAlign.Center)
    .alignItems(HorizontalAlign.Center)

  }
}
复制代码
EmitterUtil.ets
复制代码
import { emitter } from '@kit.BasicServicesKit';
import { promptAction } from '@kit.ArkUI';

class EmitterUtil {
  id: number = 1;

  // 订阅事件
  on() {
    // 定义一个eventId为1的事件。
    let event: emitter.InnerEvent = {
      eventId: 1
    };
    // 定义一个事件的回调处理函数,当收到对应的事件后执行回调函数
    let callback: Callback<emitter.EventData> = (eventData: emitter.EventData) => {
      console.info(`eventData:接收成功 ${JSON.stringify(eventData)}`);
    }

    // 收到eventId为1的事件后执行回调函数
    emitter.on(event, callback);

    // 订阅成功
    promptAction.showToast({ message: "订阅成功!" })
  }

  // 发送事件
  fire() {
    this.id = this.id + 1;
    // 定义一个eventId为1的事件,事件优先级为Low。
    let event: emitter.InnerEvent = {
      eventId: 1,
      priority: emitter.EventPriority.LOW
    };

    let eventData: emitter.EventData = {
      data: {
        content: 'emitter',
        id: this.id,
        isEmpty: false
      }
    };

    // 发送eventId为1的事件,事件内容为eventData。
    emitter.emit(event, eventData);
    promptAction.showToast({ message: "发送成功!id是" + this.id })

  }

  // 取消事件
  off() {
    // 取消eventId为1的事件。
    emitter.off(1);
    promptAction.showToast({ message: "取消成功!" })
  }
}

export const emitterUtil = new EmitterUtil();

以上是个人经验分享

相关推荐
SuperHeroWu74 小时前
【HarmonyOS 6】仿AI唤起屏幕边缘流光特效
华为·harmonyos·特效·鸿蒙6.0·流光·ai唤起·屏幕边缘
gcios6 小时前
鸿蒙-flutter 混合开发
harmonyos
特立独行的猫a6 小时前
HarmonyOS应用开发之界面列表不刷新问题Bug排查记:从现象到解决完整记录
华为·bug·harmonyos·ui刷新
安卓开发者7 小时前
鸿蒙Next的UI国际化与无障碍适老化实践:构建全球包容的数字世界
ui·华为·harmonyos
云天徽上11 小时前
【数据可视化-106】华为2025上半年财报分析:用Python和Pyecharts打造炫酷可视化大屏
开发语言·python·华为·信息可视化·数据分析·pyecharts
爱笑的眼睛1120 小时前
深入剖析 HarmonyOS ArkUI 声明式开发:状态管理艺术与最佳实践
华为·harmonyos
花先锋队长21 小时前
为何三折叠手机只有华为可以?看华为Mate XTs非凡大师就知道
华为·智能手机
安卓开发者21 小时前
鸿蒙NEXT交互机制解析:从输入设备到手势响应的全面指南
microsoft·交互·harmonyos
奶糖不太甜。1 天前
鸿蒙分布式数据同步失败全解
分布式·华为·harmonyos·数据同步