HarmonyOS 鸿蒙Next PersistentStorage 持久化的数据重启应用后数据为空

发布于 1周前 作者 ionicwang 来自 鸿蒙OS

HarmonyOS 鸿蒙Next PersistentStorage 持久化的数据重启应用后数据为空 调用 PersistentStorage.persistProp 持久化失败

2 回复

PersistentStorage和UIContext相关联,需要在UIContext明确的时候才可以调用,可以通过在runScopedTask里明确上下文。如果没有在UIContext明确的地方调用,将导致无法持久化数据。

在onWindowStageCreate中调用示例如下:

windowStage.loadContent('pages/Index', (err, data) => {
  if (err.code) {
    hilog.error(0x0000, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err) ?? '');
    return;
  }
  let window = windowStage.getMainWindow();
  window.then(win => {
    let uiContext = win.getUIContext();
    uiContext.runScopedTask(() => {
      PersistentStorage.persistProp('aProp', 47);
      // AppStorage.setOrCreate("aProp", 50)
      console.log(11 ${AppStorage.get('aProp')})
    })
  })
  hilog.info(0x0000, 'testTag', 'Succeeded in loading the content. Data: %{public}s', JSON.stringify(data) ?? '');
});

更多关于HarmonyOS 鸿蒙Next PersistentStorage 持久化的数据重启应用后数据为空的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


针对HarmonyOS(鸿蒙)系统中Next PersistentStorage持久化数据在重启应用后变为空的问题,可能的原因及解决方案如下:

  1. 存储路径或权限问题:

    • 确认持久化存储的路径是否正确设置,且应用具有对该路径的读写权限。
    • 检查是否有系统策略或安全机制阻止了应用的正常存储访问。
  2. 数据同步或写入问题:

    • 确保在数据写入PersistentStorage时,系统已完成所有写操作。可尝试使用同步写入方法。
    • 检查是否有异常或错误导致写入过程中断。
  3. 持久化机制实现:

    • 验证PersistentStorage的实现是否符合鸿蒙系统的规范。
    • 确认是否使用了正确的API和方法进行数据的持久化和读取。
  4. 应用重启行为:

    • 分析应用重启后的初始化过程,确保在重启后正确加载持久化数据。
    • 检查是否有代码逻辑错误导致数据未被正确加载或覆盖。

如果上述检查均未能解决问题,可能是系统层面的bug或特定环境下的异常。此时,建议直接联系鸿蒙系统的技术支持团队或访问官网客服寻求帮助。

如果问题依旧没法解决请联系官网客服,官网地址是 https://www.itying.com/category-93-b0.html

回到顶部