harmony next 服务卡片实时刷新

此前今日事鸿蒙版卡片数据刷新还是有点问题。

问题:

安装应用后把卡片放到桌面,在app内新增一条数据,服务卡片不刷新,需要把app进程删除重新打开,才能正常刷新数据。

原因:

卡片渲染在系统进程,创建和调用都是系统触发,即EntryFormAbility里的代码其实运行在系统进程里面,跟app进程有内存隔离。没法做到数据实时共享。

懒得上图了,卡片交互流程直接上官网看吧。

这里主要解决问题。

需要通过harmony提供的跨进程通信模块

复制代码
import commonEventManager from '@ohos.commonEventManager'

来把卡片id发给app内进行保存,才能保证在app内能实时拿到卡片id,才能保证数据能刷新到卡片上。

核心代码:

复制代码
import commonEventManager from '@ohos.commonEventManager'

class SubscriberClass {
  event_form_id = "form_id"
  publishCount: number = 1
  subscriber?: commonEventManager.CommonEventSubscriber
  // 发布者
  publish(eventType: string ,data:string){
    // next中data支持导入类型
    commonEventManager.publish(eventType,{data},(err)=>{
      if(err){
        // 失败只发3次
        if(this.publishCount<=3){
          this.publishCount++
          this.publish(eventType,data)
        }else{
          this.publishCount = 1
        }
      }else{
        this.publishCount = 1
      }
    })
  }
  // 订阅者
  subscribe(eventType: string, callback:(event?: string)=>void){
    commonEventManager.createSubscriber({ events: [eventType] }, (err, sub) => {
      if (err) {
        return console.log('logData:', `创建订阅者error ${JSON.stringify(err)}`)
      }
      this.subscriber = sub
      if (this.subscriber !== null) {
        //订阅事件
        commonEventManager.subscribe(this.subscriber, (err, data) => {
          if (err) {
            return console.error(`logData`, '订阅事件失败')
          }
          callback(data.data)
        })
      } else {
        console.error('logData:',`需要创建subscriber`);
      }
    })
  }
}

export default new SubscriberClass()

这里简单构造了一个跨进程通信的发布与订阅的对象,在卡片EntryFormAbility调用publish,把formId发布出来。在App的EntryAbility中subscribe数据。

在EntryFormAbility的onAddForm中:

复制代码
SubscriberClass.publish(SubscriberClass.event_form_id, formId)

在EntryAbility的onWindowStateCreate中:

复制代码
SubscriberClass.subscribe(SubscriberClass.event_form_id, (data?: string) => {
      if (data) {
        CardManager.get().saveCardId(this.context, data)
      }
    })

这样,才能确保在APP中任意位置能更新到卡片:

复制代码
CardManager.get().updateCard()

多说无益,直接看源码吧

相关推荐
SuperHeroWu72 小时前
【HarmonyOS 5】鸿蒙mPaaS详解
华为·harmonyos·鸿蒙·mpaas·alipay
Bruce_Liuxiaowei3 小时前
HarmonyOS NEXT~React Native在鸿蒙系统(HarmonyOS)上的适配现状与技术展望
react native·华为·harmonyos
国服第二切图仔8 小时前
鸿蒙Next API17学习新特性之组件可见区域变化事件新增支持设置事件的回调参数,限制它的执行间隔
harmonyos·鸿蒙系统
学无止境--有分享有梦想8 小时前
HarmonyOS概述
harmonyos·鸿蒙
_waylau13 小时前
华为2024年报:鸿蒙生态正在取得历史性突破
华为·开源·harmonyos
Huang兄15 小时前
#跟着若城学鸿蒙# 鸿蒙-卡证识别
harmonyos
SuperHeroWu71 天前
【HarmonyOS 5】鸿蒙碰一碰分享功能开发指南
华为·harmonyos·应用·分享·碰一碰
lqj_本人1 天前
鸿蒙OS&UniApp 制作动态加载的瀑布流布局#三方框架 #Uniapp
uni-app·harmonyos
lqj_本人1 天前
鸿蒙OS&UniApp制作一个小巧的图片浏览器#三方框架 #Uniapp
华为·uni-app·harmonyos
lqj_本人1 天前
鸿蒙OS&UniApp 开发的下拉刷新与上拉加载列表#三方框架 #Uniapp
华为·uni-app·harmonyos