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

以上是个人经验分享

相关推荐
Bigger1 小时前
Flutter 开发实战:解决华为 HarmonyOS 任务列表不显示 App 名称的终极指南
android·flutter·华为
梧桐ty5 小时前
鸿蒙应用冷启动优化:Flutter首屏秒开与白屏治理实战
flutter·华为·harmonyos
梧桐ty6 小时前
驾驭未来:基于鸿蒙的Flutter车载应用与手机端协同实战
flutter·华为·harmonyos
FrameNotWork7 小时前
HarmonyOS 教学实战(五):路由、页面生命周期与多页面架构
华为·架构·harmonyos
云和数据.ChenGuang8 小时前
鸿蒙电视的核心技术
华为·harmonyos·数据库运维工程师·运维教程
AirDroid_cn9 小时前
鸿蒙NEXT:升级系统时提示 “存储空间不足” 如何解决?
华为·harmonyos
盐焗西兰花10 小时前
鸿蒙学习实战之路-数据持久化键值型数据库KV-Store全攻略
数据库·学习·harmonyos
磊少工作室_CTO12 小时前
鸿蒙Next —— 状态管理实践
harmonyos·mvvm·客户端
御承扬13 小时前
鸿蒙原生系列之动画效果(转场动画)
华为·harmonyos·转场动画
yenggd13 小时前
企业总部-分支-门点-数据中心使用骨干网SRv6 BE互联互通整体架构配置案例
运维·网络·计算机网络·华为·架构