【鸿蒙实战开发】记录下LocalStorage、AppStorage、PersistentStorage的持久化存储相关

45 篇文章 0 订阅
38 篇文章 0 订阅

前言

记录下最近适配鸿蒙用到状态存储的一些理解。

理解

虽然官方文档中将管理应用存储分为了LocalStorage(页面级)、AppStorage(应用级)、PersistentStorage(持久化存储)三种类型。
使用下来,感觉其实只要关注LocalStorage(页面级)、AppStorage(应用级)两种类型就好了,而PersistentStorage与其说是存储管理,不如说是存储标记,具体的看下问吧。

LocalStorage页面级存储

在鸿蒙中LocalStorage从概念和理解是都完全不同于 Web的 localStorage。他相当于设置了一个只作用于某个页面的存储区。
别看官方文档写了一大堆,实际上用法无外乎以下:

●声明:new LocalStorage(object) ,创建一个LocalStorage,可以设置初始内容。
●绑定到页面:在 页面的组件 上使用 @Entry(storage)进行绑定。绑定后,该页面组件、以及子组件都可使用该存储中的数据了。
●使用:

○@LocalStorageProps:单向绑定,也就是页面改变了值的内容,不会影响到 localStore 中存储数据
○@LocalStorageLink:双向绑定,也就是页面改变了值的内容,会一并影响到 localStore 中存储数据
○PS: 值得一提的是,鸿蒙中@Props 都是单向绑定,@Link 都是双向绑定。

  //初始化
 let para: Record<string, number> = { 'PropA': 47 };
 let storage: LocalStorage = new LocalStorage(para);
 
 //添加创建值
 storage.setOrCreate('PropB', new PropB(50));

 //绑定
 @Entry(storage)
 @Component
struct CompA {

   //使用
   @LocalStorageProps('PropA') childLinkNumber: number = 1;
   @LocalStorageLink('PropB') childPropsNumber: number = 1;
        
}

AppStorage页面级存储

AppStorage和LocalStorage的区别,主要凸显在两个地方。

1.AppStorage是作用于全局的,整个应用周期, 无需声明,也无需进行@Entry(storage)绑定
2.AppStorage配合PersistentStorage可以实现持久化存储(下面细讲)。

//直接设置值
AppStorage.setOrCreate('PropA', 47);
AppStorage.setOrCreate('PropB', new PropB(50));

struct CompA {

   //然后使用
   @StorageProps('PropA') childLinkNumber: number = 1;
   @StorageLink('PropB') childPropsNumber: number = 1;
        
}

PersistentStorage持久化存储

PersistentStorage虽然名字和AppStorage、LocalStorage很像,但实际上他不负责存储相关的操作。它的作用其实是声明、或者标记。
通过persistProp声明一个键值对,然后AppStorage存储的该数据就变成了持久化存储了。这句话有几个注意点。

1.因为是声明:所以声明一次就好了,建议在 app 启动后就声明。
2.因为是AppStorage中该数据变成持久化存储,所以针对该数据的操作都通过AppStorage来进行操作。重点啊!敲黑板
3.声明一定要在 AppStorage使用之前!重点,这是个坑。

   //声明了属性aProp,并设置默认值。(该默认值,是未存储过的时候才使用的默认值)
    PersistentStorage.persistProp('aProp', 47);
    // 获取持久化值
    AppStorage.get('aProp')
    // 使用
    AppStorage.setOrCreate('aProp',36)

错误示范,如果声明在AppStorage使用之后,那会造成你获取的将不是持久化存储的值。

    // 使用
    AppStorage.setOrCreate('aProp',36)
     //声明了属性aProp,并设置默认值。(该默认值,是未存储过的时候才使用的默认值)
    PersistentStorage.persistProp('aProp', 47);
    // 获取持久化值
    AppStorage.get('aProp')

错误示范二:
const class 在初始化时使用 AppStorage.setOrCreate,但是在 EntryAbility.onCreate中声明。
如果你以为EntryAbility.onCreate是先执行的那就错了。例如以下创建 class,该 account 的constructor,就会在EntryAbility.onCreate 之前调用。 这个顺序非常重要.

export const account = new Account();

既然PersistentStorage既然是标记一个AppStorage的一个值是否持久化,那如何取消持久化呢?

//取消持久化标记
PersistentStorage.deleteProp('key')

存储的数据如何查看????

1.studio -> Device File Browser
2.找到应用的persistent_storage存储文件,路径中 el2,和 el1 应该是引擎版本:/data/app/el2/100/base/[包名]/haps/entry/files/persistent_storage
3.玩 android 的有没有眼前一亮 哈哈哈哈,这不就是sharepreference嘛。
在这里插入图片描述

写在最后

有很多小伙伴不知道学习哪些鸿蒙开发技术?不知道需要重点掌握哪些鸿蒙应用开发知识点?而且学习时频繁踩坑,最终浪费大量时间。所以有一份实用的鸿蒙(HarmonyOS NEXT)资料用来跟着学习是非常有必要的。

这份鸿蒙(HarmonyOS NEXT)资料包含了鸿蒙开发必掌握的核心知识要点,内容包含了(ArkTS、ArkUI开发组件、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战等等)鸿蒙(HarmonyOS NEXT)技术知识点。

希望这一份鸿蒙学习资料能够给大家带来帮助,有需要的小伙伴自行领取,限时开源,先到先得~无套路领取!!

获取这份完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料

鸿蒙(HarmonyOS NEXT)最新学习路线

在这里插入图片描述

有了路线图,怎么能没有学习资料呢,小编也准备了一份联合鸿蒙官方发布笔记整理收纳的一套系统性的鸿蒙(OpenHarmony )学习手册(共计1236页)与鸿蒙(OpenHarmony )开发入门教学视频,内容包含:ArkTS、ArkUI、Web开发、应用模型、资源分类…等知识点。

获取以上完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料

《鸿蒙 (OpenHarmony)开发入门教学视频》

在这里插入图片描述

《鸿蒙生态应用开发V3.0白皮书》

在这里插入图片描述

《鸿蒙 (OpenHarmony)开发基础到实战手册》

OpenHarmony北向、南向开发环境搭建

在这里插入图片描述

《鸿蒙开发基础》

●ArkTS语言
●安装DevEco Studio
●运用你的第一个ArkTS应用
●ArkUI声明式UI开发
.……
在这里插入图片描述

《鸿蒙开发进阶》

●Stage模型入门
●网络管理
●数据管理
●电话服务
●分布式应用开发
●通知与窗口管理
●多媒体技术
●安全技能
●任务管理
●WebGL
●国际化开发
●应用测试
●DFX面向未来设计
●鸿蒙系统移植和裁剪定制
……
在这里插入图片描述

《鸿蒙进阶实战》

●ArkTS实践
●UIAbility应用
●网络案例
……
在这里插入图片描述

获取以上完整鸿蒙HarmonyOS学习资料,请点击→纯血版全套鸿蒙HarmonyOS学习资料

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值