鸿蒙应用开发中用到的持久化方案

Preferences-首选项

主要用于保存一些配置信息,为应用提供Key-Value键值型的数据处理能力,支持应用持久化轻量级数据,并对其修改和查询;

Preferences中的数据会被缓存在内存中,因此它可以获得更快的存取速度,不太适合存储大量数据的场景

首选项基本操作

1、获得首选项实例

通过getPreferenceSync,以同步方式获得首选项实例

复制代码
import { preferences } from '@kit.ArkData';  // 导入首选项api
const KEY = 'searchStore'
// 获得首选项实例
const preferencesInstance = preferences.getPreferencesSync(getContext(), { name: KEY })
2、向首选项写入数据并持久化到文件中

使用put方法添加数据后,数据会被缓存在内存中,

使用flush方法则用于将这些缓存数据写入到文件中,以确保数据的持久化存储

复制代码
// 利用首选项实例的put方法可以写入数据
// 第一个参数KEY:要写入数据的key
// 第二个参数value:要写入的数据
preferencesInstance.put(KEY, 要保存的值)

// 将数据写入到文件中
preferencesInstance.flush()
3、获取首选项数据

get方法获取首选项数据

复制代码
// 利用首选项实例的get方法可以读取KEY中的数据
// 第一个参数KEY:要获取数据的key
// 第二个参数defValue:如果没有读取到数据,则返回默认数据
preferencesInstance.get(KEY, 默认值)
4、删除指定KEY的数据

deleteSync删除指定key的数据

复制代码
preferencesInstance.deleteSync(KEY);
5、获取首选项文件的目录
复制代码
getContext().preferencesDir

PersistentStorage长链接

支持简单类型,如number、string、boolean、enum等,如果要支持对象类型,可以转化成json字符串。

PersistentStorage将选定的AppStorage属性保留在设备磁盘上,通过 AppStorage 的 Api 来获取并修改即可,AppStorage 的修改会自动同步到PersistentStorage中。

持久化变量最好小于2kb,因为PersistentStorage写入磁盘的操作是同步的,大量的数据本地化读写会同步在UI线程中执行,影响UI渲染性能。

如果开发者需要存储大量的数据,建议使用数据库api

核心步骤

1、初始化PersistentStorage
复制代码
PersistentStorage.persistProp<string>('name','jerry')
2、通过 AppStorage 获取并修改数据
复制代码
 @StorageLink('name') name:string=''

3、清除数据方法

PersistentStorage.DeleteProp方法用于删除指定键对应的数据

storage.clear方法是用于清空整个存储区域的所有数据。

注意事项

PersistentStorage不支持嵌套对象(对象数组,对象的属性是对象等)。因为目前框架无法检测AppStorage中嵌套对象(包括数组)值的变化,所以无法写回到PersistentStorage中。

总结

总的来说,Preferences适用于存储小型配置项数据,而PersistentStorage适用于存储需要在应用关闭或设备重启后仍然保留的数据

相关推荐
春蕾夏荷_72829772510 小时前
DevEco Studio 创建第一个应用程序
鸿蒙·deveco studio
waeng_luo2 天前
[鸿蒙2025领航者闯关] Scroll滑动容器与布局优化技巧
harmonyos·鸿蒙·鸿蒙2025领航者闯关·鸿蒙6实战·开发者年度总结
waeng_luo2 天前
[鸿蒙2025领航者闯关] 表单验证与用户输入处理最佳实践
开发语言·前端·鸿蒙·鸿蒙2025领航者闯关·鸿蒙6实战·开发者年度总结
kirk_wang2 天前
Flutter三方库鸿蒙适配实战:从原理到落地
flutter·移动开发·跨平台·arkts·鸿蒙
汉堡黄•᷄ࡇ•᷅2 天前
鸿蒙开发:案例集合List:ListItem拖拽(交换位置,过渡动画)(性能篇)
华为·harmonyos·鸿蒙·鸿蒙系统
Mr_Hu4043 天前
鸿蒙开发学习笔记-生命周期小记
笔记·学习·harmonyos·鸿蒙
kirk_wang3 天前
Flutter 图表库 fl_chart 鸿蒙端适配实践
flutter·移动开发·跨平台·arkts·鸿蒙
waeng_luo3 天前
[鸿蒙2025领航者闯关] 鸿蒙应用中如何管理组件状态?
前端·harmonyos·鸿蒙·鸿蒙2025领航者闯关·鸿蒙6实战·开发者年度总结
不老刘3 天前
HarmonyOS ArkTS IconFont 实践指南
harmonyos·鸿蒙·iconfont
kirk_wang3 天前
Flutter视频播放器在鸿蒙系统(HarmonyOS)上的适配实践
flutter·移动开发·跨平台·arkts·鸿蒙