# CommonEventSubscriber > **说明:** > > 本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 ## 使用说明 在使用CommonEventSubscriber的功能前,需要通过CommonEvent.createSubscriber获取subscriber对象。 ```ts import CommonEvent from '@ohos.commonEvent'; import CommonEventManager from '@ohos.commonEventManager'; import Base from '@ohos.base'; let subscriber:CommonEventManager.CommonEventSubscriber; // 用于保存创建成功的订阅者对象,后续使用其完成订阅及退订的动作 // 订阅者信息 let subscribeInfo:CommonEventManager.CommonEventSubscribeInfo = { events: ["event"] }; // 创建订阅者回调 function createCB(err:Base.BusinessError, commonEventSubscriber:CommonEventManager.CommonEventSubscriber) { if (err.code) { console.error(`createSubscriber failed, code is ${err.code}`); } else { console.info("createSubscriber"); subscriber = commonEventSubscriber; } } // 创建订阅者 CommonEvent.createSubscriber(subscribeInfo, createCB); ``` ## getCode getCode(callback: AsyncCallback\): void 以回调形式获取公共事件代码。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | ---------------------- | ---- | ------------------ | | callback | AsyncCallback\ | 是 | 公共事件代码。 | **示例:** ```ts //获取有序公共事件代码回调 function getCodeCB(err:Base.BusinessError, code:number) { if (err.code) { console.error(`getCode failed, code is ${err.code}, message is ${err.message}`); } else { console.info("getCode " + JSON.stringify(code)); } } subscriber.getCode(getCodeCB); ``` ## getCode getCode(): Promise\ 以Promise形式获取公共事件代码。 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ---------------- | -------------------- | | Promise\ | 公共事件代码。 | **示例:** ```ts subscriber.getCode().then((code:number) => { console.info("getCode " + JSON.stringify(code)); }).catch((err:Base.BusinessError) => { console.error(`getCode failed, code is ${err.code}, message is ${err.message}`); }); ``` ## getCodeSync getCodeSync(): number getCode的同步接口 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ---------------- | -------------------- | | number | 公共事件代码。 | **示例:** ```ts let code = subscriber.getCodeSync(); console.info("getCodeSync " + JSON.stringify(code)); ``` ## setCode setCode(code: number, callback: AsyncCallback\): void 以回调形式设置公共事件的代码。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------------------- | ---- | ---------------------- | | code | number | 是 | 公共事件的代码。 | | callback | AsyncCallback\ | 是 | 表示被指定的回调方法。 | **示例:** ```ts //设置有序公共事件的代码回调 function setCodeCB(err:Base.BusinessError) { if (err.code) { console.error(`setCode failed, code is ${err.code}, message is ${err.message}`); } else { console.info("setCode"); } } subscriber.setCode(1, setCodeCB); ``` ## setCode setCode(code: number): Promise\ 以Promise形式设置公共事件的代码。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | ------ | ------ | ---- | ------------------ | | code | number | 是 | 公共事件的代码。 | **返回值:** | 类型 | 说明 | | ---------------- | -------------------- | | Promise\ | 返回一个Promise的结果。 | **示例:** ```ts subscriber.setCode(1).then(() => { console.info("setCode"); }).catch((err:Base.BusinessError) => { console.error(`setCode failed, code is ${err.code}, message is ${err.message}`); }); ``` ## setCodeSync setCodeSync(code: number): void setCode的同步接口 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | ------ | ------ | ---- | ------------------ | | code | number | 是 | 公共事件的代码。 | **示例:** ```ts try { subscriber.setCodeSync(1); } catch (err) { console.error(`setCodeSync failed, code is ${err.code}, message is ${err.message}`); } ``` ## getData getData(callback: AsyncCallback\): void 以回调形式获取公共事件的数据。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | ---------------------- | ---- | -------------------- | | callback | AsyncCallback\ | 是 | 公共事件的数据。 | **示例:** ```ts //获取有序公共事件代码数据回调 function getDataCB(err:Base.BusinessError, data:string) { if (err.code) { console.error(`getData failed, code is ${err.code}, message is ${err.message}`); } else { console.info("getData " + JSON.stringify(data)); } } subscriber.getData(getDataCB); ``` ## getData getData(): Promise\ 以Promise形式获取公共事件的数据。 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ---------------- | ------------------ | | Promise\ | 公共事件的数据。 | **示例:** ```ts subscriber.getData().then((data:string) => { console.info("getData " + JSON.stringify(data)); }).catch((err:Base.BusinessError) => { console.error(`getData failed, code is ${err.code}, message is ${err.message}`); }); ``` ## getDataSync getDataSync(): string getData的同步接口 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ---------------- | ------------------ | | string | 公共事件的数据。 | **示例:** ```ts let data = subscriber.getDataSync(); console.info("getDataSync " + JSON.stringify(data)); ``` ## setData setData(data: string, callback: AsyncCallback\): void 以回调形式设置公共事件的数据。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------------------- | ---- | -------------------- | | data | string | 是 | 公共事件的数据。 | | callback | AsyncCallback\ | 是 | 表示被指定的回调方法。 | **示例:** ```ts //设置有序公共事件的结果数据回调 function setDataCB(err:Base.BusinessError) { if (err.code) { console.error(`setCode failed, code is ${err.code}, message is ${err.message}`); } else { console.info("setData"); } } subscriber.setData("publish_data_changed", setDataCB); ``` ## setData setData(data: string): Promise\ 以Promise形式设置公共事件的果数据。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | ------ | ------ | ---- | -------------------- | | data | string | 是 | 公共事件的数据。 | **返回值:** | 类型 | 说明 | | ---------------- | -------------------- | | Promise\ | 返回一个Promise的结果。 | **示例:** ```ts subscriber.setData("publish_data_changed").then(() => { console.info("setData"); }).catch((err:Base.BusinessError) => { console.error(`setCode failed, code is ${err.code}, message is ${err.message}`); }); ``` ## setDataSync setDataSync(data: string): void setData的同步接口。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | ------ | ------ | ---- | -------------------- | | data | string | 是 | 公共事件的数据。 | **示例:** ```ts try { subscriber.setDataSync("publish_data_changed"); } catch (err) { console.error(`setDataSync failed, code is ${err.code}, message is ${err.message}`); } ``` ## setCodeAndData setCodeAndData(code: number, data: string, callback:AsyncCallback\): void 以回调形式设置公共事件代码和数据。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------------------- | ---- | ---------------------- | | code | number | 是 | 公共事件的代码。 | | data | string | 是 | 公共事件的数据。 | | callback | AsyncCallback\ | 是 | 表示被指定的回调方法。 | **示例:** ```ts //设置有序公共事件的代码和数据回调 function setCodeDataCB(err:Base.BusinessError) { if (err.code) { console.error(`setCodeAndData failed, code is ${err.code}, message is ${err.message}`); } else { console.info("setCodeDataCallback"); } } subscriber.setCodeAndData(1, "publish_data_changed", setCodeDataCB); ``` ## setCodeAndData setCodeAndData(code: number, data: string): Promise\ 以Promise形式设置公共事件的代码和数据。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | ------ | ------ | ---- | -------------------- | | code | number | 是 | 公共事件的代码。 | | data | string | 是 | 公共事件的数据。 | **返回值:** | 类型 | 说明 | | ---------------- | -------------------- | | Promise\ | 返回一个Promise。 | **示例:** ```ts subscriber.setCodeAndData(1, "publish_data_changed").then(() => { console.info("setCodeAndData"); }).catch((err:Base.BusinessError) => { console.error(`setCodeAndData failed, code is ${err.code}, message is ${err.message}`); }); ``` ## setCodeAndDataSync setCodeAndData的同步接口。 setCodeAndDataSync(code: number, data: string): void **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | ------ | ------ | ---- | -------------------- | | code | number | 是 | 公共事件的代码。 | | data | string | 是 | 公共事件的数据。 | **示例:** ```ts try { subscriber.setCodeAndDataSync(1, "publish_data_changed"); } catch (err) { console.error(`setCodeAndData failed, code is ${err.code}, message is ${err.message}`); } ``` ## isOrderedCommonEvent isOrderedCommonEvent(callback: AsyncCallback\): void 以回调形式查询当前公共事件的是否为有序公共事件。 返回true代表是有序公共事件,false代表不是有序公共事件。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | ----------------------- | ---- | ---------------------------------- | | callback | AsyncCallback\ | 是 | 当前公共事件的是否为有序公共事件。 | **示例:** ```ts //获取当前公共事件是否为有序事件的回调 function isOrderedCB(err:Base.BusinessError, isOrdered:boolean) { if (err.code) { console.error(`isOrderedCommonEvent failed, code is ${err.code}, message is ${err.message}`); } else { console.info("isOrdered " + JSON.stringify(isOrdered)); } } subscriber.isOrderedCommonEvent(isOrderedCB); ``` ## isOrderedCommonEvent isOrderedCommonEvent(): Promise\ 以Promise形式查询当前公共事件的是否为有序公共事件。 返回true代表是有序公共事件,false代表不是有序公共事件。 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ----------------- | -------------------------------- | | Promise\ | 当前公共事件的是否为有序公共事件。 | **示例:** ```ts subscriber.isOrderedCommonEvent().then((isOrdered:boolean) => { console.info("isOrdered " + JSON.stringify(isOrdered)); }).catch((err:Base.BusinessError) => { console.error(`isOrdered failed, code is ${err.code}, message is ${err.message}`); }); ``` ## isOrderedCommonEventSync isOrderedCommonEventSync(): boolean isOrderedCommonEvent的同步接口 返回true代表是有序公共事件,false代表不是有序公共事件。 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ----------------- | -------------------------------- | | boolean | 当前公共事件的是否为有序公共事件。 | **示例:** ```ts let isOrdered = subscriber.isOrderedCommonEventSync(); console.info("isOrdered " + JSON.stringify(isOrdered)); ``` ## isStickyCommonEvent isStickyCommonEvent(callback: AsyncCallback\): void 以回调形式检查当前公共事件是否为一个粘性事件。 返回true代表是粘性公共事件,false代表不是粘性公共事件。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | ----------------------- | ---- | ---------------------------------- | | callback | AsyncCallback\ | 是 | 当前公共事件的是否为粘性公共事件。 | **示例:** ```ts //获取当前公共事件是否为粘性事件的回调 function isStickyCB(err:Base.BusinessError, isSticky:boolean) { if (err.code) { console.error(`isStickyCommonEvent failed, code is ${err.code}, message is ${err.message}`); } else { console.info("isSticky " + JSON.stringify(isSticky)); } } subscriber.isStickyCommonEvent(isStickyCB); ``` ## isStickyCommonEvent isStickyCommonEvent(): Promise\ 以Promise形式检查当前公共事件是否为一个粘性事件。 返回true代表是粘性公共事件,false代表不是粘性公共事件。 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ----------------- | -------------------------------- | | Promise\ | 当前公共事件的是否为粘性公共事件。 | **示例:** ```ts subscriber.isStickyCommonEvent().then((isSticky:boolean) => { console.info("isSticky " + JSON.stringify(isSticky)); }).catch((err:Base.BusinessError) => { console.error(`isSticky failed, code is ${err.code}, message is ${err.message}`); }); ``` ## isStickyCommonEventSync isStickyCommonEventSync(): boolean isStickyCommonEvent的同步接口。 返回true代表是粘性公共事件,false代表不是粘性公共事件。 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ----------------- | -------------------------------- | | boolean | 当前公共事件的是否为粘性公共事件。 | **示例:** ```ts let isSticky = subscriber.isStickyCommonEventSync(); console.info("isSticky " + JSON.stringify(isSticky)); ``` ## abortCommonEvent abortCommonEvent(callback: AsyncCallback\): void 以回调形式取消当前的有序公共事件,取消后,有序公共事件不再向下一个订阅者传递。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------------------- | ---- | -------------------- | | callback | AsyncCallback\ | 是 | 取消当前的有序公共事件。 | **示例:** ```ts //取消当前有序公共事件的回调 function abortCB(err:Base.BusinessError) { if (err.code) { console.error(`abortCommonEvent failed, code is ${err.code}, message is ${err.message}`); } else { console.info("abortCommonEvent"); } } subscriber.abortCommonEvent(abortCB); ``` ## abortCommonEvent abortCommonEvent(): Promise\ 以Promise形式取消当前的有序公共事件,取消后,公共事件不再向下一个订阅者传递。 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ---------------- | -------------------- | | Promise\ | 返回一个Promise的结果。 | **示例:** ```ts subscriber.abortCommonEvent().then(() => { console.info("abortCommonEvent"); }).catch((err:Base.BusinessError) => { console.error(`abortCommonEvent failed, code is ${err.code}, message is ${err.message}`); }); ``` ## abortCommonEventSync abortCommonEventSync(): void abortCommonEvent的同步接口 **系统能力**:`SystemCapability.Notification.CommonEvent` **示例:** ```ts subscriber.abortCommonEventSync(); ``` ## clearAbortCommonEvent clearAbortCommonEvent(callback: AsyncCallback\): void 以回调形式清除当前有序公共事件。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------------------- | ---- | -------------------- | | callback | AsyncCallback\ | 是 | 表示被指定的回调方法。 | **示例:** ```ts //清除当前公共事件取消状态的回调 function clearAbortCB(err:Base.BusinessError) { if (err.code) { console.error(`clearAbortCommonEvent failed, code is ${err.code}, message is ${err.message}`); } else { console.info("clearAbortCommonEvent"); } } subscriber.clearAbortCommonEvent(clearAbortCB); ``` ## clearAbortCommonEvent clearAbortCommonEvent(): Promise\ 以Promise形式清除当前有序公共事件。 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ---------------- | -------------------- | | Promise\ | 返回一个Promise的结果。 | **示例:** ```ts subscriber.clearAbortCommonEvent().then(() => { console.info("clearAbortCommonEvent"); }).catch((err:Base.BusinessError) => { console.error(`clearAbortCommonEvent failed, code is ${err.code}, message is ${err.message}`); }); ``` ## clearAbortCommonEventSync clearAbortCommonEventSync(): void clearAbortCommonEvent的同步接口 **系统能力**:`SystemCapability.Notification.CommonEvent` **示例:** ```ts subscriber.clearAbortCommonEventSync(); ``` ## getAbortCommonEvent getAbortCommonEvent(callback: AsyncCallback\): void 以回调形式获取当前有序公共事件是否取消的状态。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | ----------------------- | ---- | ---------------------------------- | | callback | AsyncCallback\ | 是 | 表示当前有序公共事件是否取消的状态。 | **示例:** ```ts //获取当前有序公共事件是否取消的回调 function getAbortCB(err:Base.BusinessError, abortEvent:boolean) { if (err.code) { console.error(`getAbortCommonEvent failed, code is ${err.code}, message is ${err.message}`); } else { console.info("abortCommonEvent " + abortEvent) } } subscriber.getAbortCommonEvent(getAbortCB); ``` ## getAbortCommonEvent getAbortCommonEvent(): Promise\ 以Promise形式获取当前有序公共事件是否取消的状态。 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ----------------- | ---------------------------------- | | Promise\ | 表示当前有序公共事件是否取消的状态。 | **示例:** ```ts subscriber.getAbortCommonEvent().then((abortEvent:boolean) => { console.info("abortCommonEvent " + JSON.stringify(abortEvent)); }).catch((err:Base.BusinessError) => { console.error(`getAbortCommonEvent failed, code is ${err.code}, message is ${err.message}`); }); ``` ## getAbortCommonEventSync getAbortCommonEventSync(): boolean getAbortCommonEvent的同步接口。 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ----------------- | ---------------------------------- | | boolean | 表示当前有序公共事件是否取消的状态。 | **示例:** ```ts let abortEvent = subscriber.getAbortCommonEventSync(); console.info("getAbortCommonEventSync " + JSON.stringify(abortEvent)); ``` ## getSubscribeInfo getSubscribeInfo(callback: AsyncCallback\): void 以回调形式获取订阅者的订阅信息。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | ------------------------------------------------------------ | ---- | ---------------------- | | callback | AsyncCallback\<[CommonEventSubscribeInfo](./js-apis-inner-commonEvent-commonEventSubscribeInfo.md)> | 是 | 表示订阅者的订阅信息。 | **示例:** ```ts //获取订阅者信息回调 function getCB(err:Base.BusinessError, subscribeInfo:CommonEventManager.CommonEventSubscribeInfo) { if (err.code) { console.error(`getSubscribeInfo failed, code is ${err.code}, message is ${err.message}`); } else { console.info("subscribeInfo " + JSON.stringify(subscribeInfo)); } } subscriber.getSubscribeInfo(getCB); ``` ## getSubscribeInfo getSubscribeInfo(): Promise\ 以Promise形式获取订阅者的订阅信息。 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ------------------------------------------------------------ | ---------------------- | | Promise\<[CommonEventSubscribeInfo](./js-apis-inner-commonEvent-commonEventSubscribeInfo.md)> | 表示订阅者的订阅信息。 | **示例:** ```ts subscriber.getSubscribeInfo().then((subscribeInfo:CommonEventManager.CommonEventSubscribeInfo) => { console.info("subscribeInfo " + JSON.stringify(subscribeInfo)); }).catch((err:Base.BusinessError) => { console.error(`getSubscribeInfo failed, code is ${err.code}, message is ${err.message}`); }); ``` ## getSubscribeInfoSync getSubscribeInfoSync(): CommonEventSubscribeInfo getSubscribeInfo的同步接口。 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ------------------------------------------------------------ | ---------------------- | | [CommonEventSubscribeInfo](./js-apis-inner-commonEvent-commonEventSubscribeInfo.md) | 表示订阅者的订阅信息。 | **示例:** ```ts let subscribeInfo = subscriber.getSubscribeInfoSync(); console.info("subscribeInfo " + JSON.stringify(subscribeInfo)); ``` ## finishCommonEvent9+ finishCommonEvent(callback: AsyncCallback\): void 以回调形式结束当前有序公共事件。 **系统能力**:`SystemCapability.Notification.CommonEvent` **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------------------- | ---- | -------------------------------- | | callback | AsyncCallback\ | 是 | 表示有序公共事件结束后的回调函数。 | **示例:** ```ts //结束当前有序公共事件的回调 function finishCB(err:Base.BusinessError) { if (err.code) { console.error(`finishCommonEvent failed, code is ${err.code}, message is ${err.message}`); } else { console.info("FinishCommonEvent"); } } subscriber.finishCommonEvent(finishCB); ``` ## finishCommonEvent9+ finishCommonEvent(): Promise\ 以Promise形式结束当前有序公共事件。 **系统能力**:`SystemCapability.Notification.CommonEvent` **返回值:** | 类型 | 说明 | | ---------------- | -------------------- | | Promise\ | 返回一个Promise的结果。 | **示例:** ```ts subscriber.finishCommonEvent().then(() => { console.info("FinishCommonEvent"); }).catch((err:Base.BusinessError) => { console.error(`finishCommonEvent failed, code is ${err.code}, message is ${err.message}`); }); ```