【HarmonyOS 4.0】@ohos.events.emitter (Emitter)

  1. B页面需要感知到A页面的点击事件,进而触发B页面的刷新逻辑,类似这种公共的事件通知,就可通过 emitter 来实现。
  1. 导入 emitter 模块
  1. 发布和订阅都需要导入 emitter 模块。
  2. import emitter from '@ohos.events.emitter'
  1. emitter.emit
  1. 发送一个事件到事件队列。发送自定义事件。
  2. emitter.emit(event: InnerEvent 1 , data?: EventData 2 ): void
emitter.emit({
  eventId: 1,
  priority: emitter.EventPriority.IMMEDIATE
})
  1. emitter.on
  1. 持续订阅某个事件以及接收事件的回调处理。订阅自定义事件。
  2. 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 = 0

async getPostInfoPage() {
  let response = await getAllPost({
    page: this.page,
    size: 10
  })
  response.records.forEach(item => {
    this.postInfoList.push(item)
  })
  this.total = response.total
  this.page += 1
}

refresh() {
  this.postInfoList = []
  this.total = 0
  this.page = 1
  this.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 = 0
    this.page = 1
  }
}
  1. emitter.once
  1. 单次订阅某个事件以及接收事件的回调处理,接收到回调处理后自动取消订阅。
  2. emitter.once(event: InnerEvent 1 , callback: Callback): void
  1. emitter.off
  1. 取消订阅某个事件。
  2. emitter.off(eventId: number): void

  1. InnerEvent 进程内的自定义事件对象。
    {
    eventId: number, 事件的ID,由开发者定义用来辨别事件。
    priority: emitter.EventPriority 3
    } ↩︎ ↩︎ ↩︎

  2. EventData 发送事件时传递的数据。类型为 [key: string]: any。 ↩︎

  3. EventPriority 用于表示事件被投递的优先级。
    IMMEDIATE(0):表示事件被立即投递。
    HIGH(1):表示事件先于LOW优先级投递。
    LOW(2):表示事件优于IDLE优先级投递,事件的默认优先级是LOW。
    IDLE(3):表示在没有其他事件的情况下,才投递该事件。 ↩︎

你可能感兴趣的:(华为,HarmonyOS,4.0)