公共事件发布

2024-01-25 12:28 更新

场景介绍

当需要发布某个自定义公共事件时,可以通过publish()方法发布事件。发布的公共事件可以携带数据,供订阅者解析并进行下一步处理。

注意

已发出的粘性公共事件后来订阅者也可以接收到,其他公共事件都需要先订阅再接收,订阅参考公共事件订阅章节

接口说明

详细接口见接口文档

接口名

接口描述

publish(event: string, callback: AsyncCallback)

发布公共事件。

publish(event: string, options: CommonEventPublishData, callback: AsyncCallback)

指定发布信息并发布公共事件。

发布不携带信息的公共事件

不携带信息的公共事件,只能发布无序公共事件。

  1. 导入CommonEvent模块。

    1. import commonEvent from '@ohos.commonEventManager';
  2. 传入需要发布的事件名称和回调函数,发布事件。

    1. // 发布公共事件
    2. commonEvent.publish("usual.event.SCREEN_OFF", (err) => {
    3. if (err) {
    4. console.error(`[CommonEvent] PublishCallBack err=${JSON.stringify(err)}`);
    5. } else {
    6. console.info(`[CommonEvent] Publish success`);
    7. }
    8. })

发布携带信息的公共事件

携带信息的公共事件,可以发布为无序公共事件、有序公共事件和粘性事件,可以通过参数CommonEventPublishData的isOrdered、isSticky的字段进行设置。

  1. 导入CommonEvent模块。

    1. import commonEvent from '@ohos.commonEventManager';
  2. 传入需要发布的事件名称和回调函数,发布事件。

    1. // 公共事件相关信息
    2. let options = {
    3. code: 1, // 公共事件的初始代码
    4. data: "initial data", // 公共事件的初始数据
    5. }
  3. 传入需要发布的事件名称、需要发布的指定信息和回调函数,发布事件。

    1. // 发布公共事件
    2. commonEventManager.publish("custom_event", options, (err) => {
    3. if (err) {
    4. console.error('[CommonEvent] PublishCallBack err=' + JSON.stringify(err));
    5. } else {
    6. console.info('[CommonEvent] Publish success')
    7. }
    8. })
以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号