- B页面需要感知到A页面的点击事件,进而触发B页面的刷新逻辑,类似这种公共的事件通知,就可通过 emitter 来实现。
- 导入 emitter 模块
- 发布和订阅都需要导入 emitter 模块。
import emitter from '@ohos.events.emitter'
- emitter.emit
- 发送一个事件到事件队列。发送自定义事件。
- emitter.emit(event: InnerEvent 1 , data?: EventData 2 ): void
emitter.emit({eventId: 1,priority: emitter.EventPriority.IMMEDIATE
})
- emitter.on
- 持续订阅某个事件以及接收事件的回调处理。订阅自定义事件。
- emitter.on(event: InnerEvent 1 , callback: Callback): void
@State postInfoList: Array<PostInfo> = [new PostInfo(this.init_post)]
@StorageProp('token') @Watch('onTokenChange') token: string = ''
@State page: number = 1
@State total: number = 0async getPostInfoPage() {let response = await getAllPost({page: this.page,size: 10})response.records.forEach(item => {this.postInfoList.push(item)})this.total = response.totalthis.page += 1
}refresh() {this.postInfoList = []this.total = 0this.page = 1this.getPostInfoPage()
}aboutToAppear(): void {if (this.token) {this.getPostInfoPage()}emitter.on({ eventId: 1 }, () => {this.refresh()})
}onTokenChange() {if (this.token) {this.getPostInfoPage()} else {this.postInfoList = []this.total = 0this.page = 1}
}
- emitter.once
- 单次订阅某个事件以及接收事件的回调处理,接收到回调处理后自动取消订阅。
- emitter.once(event: InnerEvent 1 , callback: Callback): void
- emitter.off
- 取消订阅某个事件。
- emitter.off(eventId: number): void
InnerEvent 进程内的自定义事件对象。
{
eventId: number, 事件的ID,由开发者定义用来辨别事件。
priority: emitter.EventPriority 3
} ↩︎ ↩︎ ↩︎EventData 发送事件时传递的数据。类型为 [key: string]: any。 ↩︎
EventPriority 用于表示事件被投递的优先级。
IMMEDIATE(0):表示事件被立即投递。
HIGH(1):表示事件先于LOW优先级投递。
LOW(2):表示事件优于IDLE优先级投递,事件的默认优先级是LOW。
IDLE(3):表示在没有其他事件的情况下,才投递该事件。 ↩︎