鸿蒙:使用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();

以上是个人经验分享

相关推荐
万少27 分钟前
记 HarmonyOS 开发中的一个小事件 怒提华为工单
前端·harmonyos
辛宝Otto_WebWorker42 分钟前
自力更生!uniapp 使用鸿蒙 UTS 使用三方依赖、本地依赖
uni-app·harmonyos
程序员潘Sir2 小时前
使用Tabs选项卡组件快速搭建鸿蒙APP框架
harmonyos·鸿蒙
编程乐学3 小时前
鸿蒙原创--DevEco Studio开发的音乐播放器App
华为·harmonyos·音乐播放器·deveco studio·大作业·鸿蒙大作业
米羊12112 小时前
【鸿蒙心迹】摸蓝图,打地基
华为·harmonyos
pangtout15 小时前
华为坤灵:点燃中小企业智能化的星火
华为
一天前17 小时前
ArkUI 中实现点击涟漪效果
harmonyos
HarmonyOS_SDK20 小时前
融合多元定位技术,帮助应用破解精准定位难题
harmonyos
安卓开发者1 天前
鸿蒙Next IPC Kit详解:构建高效进程间通信的完整指南
华为·harmonyos
sdszoe49221 天前
华为路由基础1
华为·静态路由配置·路由基础