Harmony中EventHub实现发布订阅

1. EventHub 核心概念

  • 发布者(Publisher):触发事件的模块(如登录模块)。
  • 订阅者(Subscriber):监听事件的模块(如购物车、个人中心)。
  • 事件(Event):携带数据的消息对象,通过唯一eventId标识。

2. 案例场景

  • 功能需求: 用户登录成功后,购物车模块和个人中心模块需实时更新UI(如显示用户名、刷新数据)。
  • 传统问题: 若直接调用购物车/个人中心的方法,会导致模块间强耦合。
  • EventHub解决方案: 登录模块发布“登录成功”事件,其他模块订阅该事件并自主响应。

3. 代码实现步骤

步骤1:定义事件类型

在公共层(Common)中定义事件ID和数据类型:

// common/src/main/ets/event/EventTypes.ets
export const EVENT_USER_LOGIN = 'user_login'; // 事件ID

export interface LoginEventData {
   
   
  userId: string;
  userName: string;
}

步骤2:发布事件(登录模块)

登录成功后,通过EventHub发布事件:

// features/login/src/main/ets/LoginService.ets
import {
   
    EventHub } from '@ohos/baseEvent';
import {
   
    EVENT_USER_LOGIN, LoginEventData } from '@common/event/EventTypes';

function handleLoginSuccess(userId: string, userName: string) {
   
   
  // 1. 本地处理登录逻辑
  // ... 

  // 2. 发布事件
  const eventData: LoginEventData = {
   
    userId, userName };
  EventHub.emit(EVENT_USER_LOGIN, eventData); // 关键发布动作
}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

bst@微胖子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值