EventHub
EventHub模塊提供了事件中心,提供訂閱、取消訂閱、觸發(fā)事件的能力。
說(shuō)明:
開(kāi)發(fā)前請(qǐng)熟悉鴻蒙開(kāi)發(fā)指導(dǎo)文檔 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]點(diǎn)擊或者復(fù)制轉(zhuǎn)到。
本模塊首批接口從API version 9開(kāi)始支持。后續(xù)版本的新增接口,采用上角標(biāo)單獨(dú)標(biāo)記接口的起始版本。
本模塊接口僅可在Stage模型下使用。
使用說(shuō)明
?在使用eventHub的功能前,需要通過(guò)Ability實(shí)例的成員變量context獲取。
import Ability from '@ohos.application.Ability'
export default class MainAbility extends Ability {
func1(){
console.log("func1 is called");
}
onForeground() {
this.context.eventHub.on("123", this.func1);
}
}
EventHub.on
on(event: string, callback: Function): void;
訂閱指定事件。
系統(tǒng)能力 :SystemCapability.Ability.AbilityRuntime.Core
參數(shù):
參數(shù)名 | 類(lèi)型 | 必填 | 說(shuō)明 |
---|---|---|---|
event | string | 是 | 事件名稱(chēng)。 |
callback | Function | 是 | 事件回調(diào),事件觸發(fā)后運(yùn)行。 |
示例:
import Ability from '@ohos.application.Ability'
export default class MainAbility extends Ability {
onForeground() {
this.context.eventHub.on("123", this.func1);
this.context.eventHub.on("123", () = > {
console.log("call anonymous func 1");
});
// 結(jié)果:
// func1 is called
// call anonymous func 1
this.context.eventHub.emit("123");
}
func1() {
console.log("func1 is called");
}
}
EventHub.off
off(event: string, callback?: Function): void;
取消訂閱指定事件。當(dāng)callback傳值時(shí),取消訂閱指定的callback;未傳值時(shí),取消訂閱該事件下所有callback。
系統(tǒng)能力 :SystemCapability.Ability.AbilityRuntime.Core
參數(shù):
參數(shù)名 | 類(lèi)型 | 必填 | 說(shuō)明 |
---|---|---|---|
event | string | 是 | 事件名稱(chēng)。 |
callback | Function | 否 | 事件回調(diào)。如果不傳callback,則取消訂閱該事件下所有callback。 |
示例:
import Ability from '@ohos.application.Ability'
export default class MainAbility extends Ability {
onForeground() {
this.context.eventHub.on("123", this.func1);
this.context.eventHub.off("123", this.func1); //取消訂閱func1
this.context.eventHub.on("123", this.func1);
this.context.eventHub.on("123", this.func2);
this.context.eventHub.off("123"); //取消訂閱func1和func2
}
func1() {
console.log("func1 is called");
}
func2() {
console.log("func2 is called");
}
}
EventHub.emit
emit(event: string, ...args: Object[]): void;
觸發(fā)指定事件。
系統(tǒng)能力 :SystemCapability.Ability.AbilityRuntime.Core
參數(shù):
參數(shù)名 | 類(lèi)型 | 必填 | 說(shuō)明HarmonyOS與OpenHarmony鴻蒙文檔籽料:mau123789是v直接拿 |
---|---|---|---|
event | string | 是 | 事件名稱(chēng)。 |
...args | Object[] | 是 | 可變參數(shù),事件觸發(fā)時(shí),傳遞給回調(diào)函數(shù)的參數(shù)。 |
示例:
import Ability from '@ohos.application.Ability'
export default class MainAbility extends Ability {
onForeground() {
this.context.eventHub.on("123", this.func1);
// 結(jié)果:
// func1 is called,undefined,undefined
this.context.eventHub.emit("123");
// 結(jié)果:
// func1 is called,1,undefined
this.context.eventHub.emit("123", 1);
// 結(jié)果:
// func1 is called,1,2
this.context.eventHub.emit("123", 1, 2);
}
func1(a, b) {
console.log("func1 is called," + a + "," + b);
}
}
-
移動(dòng)開(kāi)發(fā)
+關(guān)注
關(guān)注
0文章
52瀏覽量
10231 -
鴻蒙系統(tǒng)
+關(guān)注
關(guān)注
183文章
2639瀏覽量
67716 -
HarmonyOS
+關(guān)注
關(guān)注
79文章
2053瀏覽量
32157 -
OpenHarmony
+關(guān)注
關(guān)注
27文章
3835瀏覽量
18171 -
鴻蒙OS
+關(guān)注
關(guān)注
0文章
191瀏覽量
4882
發(fā)布評(píng)論請(qǐng)先 登錄
鴻蒙開(kāi)發(fā)接口公共事件與通知:【@ohos.commonEvent (公共事件模塊)】

鴻蒙開(kāi)發(fā)接口公共事件與通知:【Notification模塊】

鴻蒙開(kāi)發(fā)接口公共事件與通知:【@ohos.reminderAgent (后臺(tái)代理提醒)】

鴻蒙開(kāi)發(fā)接口公共事件與通知:【FFI能力】 N-API在Android、iOS平臺(tái)應(yīng)用的使用指導(dǎo)

鴻蒙原生應(yīng)用/元服務(wù)開(kāi)發(fā)-通知添加行為意圖
鴻蒙實(shí)戰(zhàn)基礎(chǔ)(ArkTS)-窗口管理
基于ArkTS語(yǔ)言的OpenHarmony APP應(yīng)用開(kāi)發(fā):公共事件的訂閱和發(fā)布
UIAbility組件與UI的數(shù)據(jù)同步介紹
HarmonyOS應(yīng)用開(kāi)發(fā)-公共事件處理
鴻蒙原生應(yīng)用/元服務(wù)開(kāi)發(fā)-Stage模型能力接口(五)
鴻蒙開(kāi)發(fā)之EventHub

鴻蒙開(kāi)發(fā)接口公共事件與通知:【FFI能力(Node-API)】

基于ArkTS語(yǔ)言的OpenHarmony APP應(yīng)用開(kāi)發(fā):公共事件的訂閱和發(fā)布

評(píng)論