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

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适用于存储需要在应用关闭或设备重启后仍然保留的数据

相关推荐
●VON2 小时前
HarmonyOS应用开发实战(基础篇)Day01-《ArkTS基本知识》
学习·华为·harmonyos·鸿蒙·von
仓颉编程语言2 天前
鸿蒙仓颉编程语言挑战赛二等奖作品:TaskGenie 打造基于仓颉语言的智能办公“任务中枢”
华为·鸿蒙·仓颉编程语言
_waylau2 天前
鸿蒙架构师修炼之道-架构师的职责是什么?
开发语言·华为·harmonyos·鸿蒙
坚果派·白晓明2 天前
在鸿蒙设备上快速验证由lycium工具快速交叉编译的C/C++三方库
c语言·c++·harmonyos·鸿蒙·编程语言·openharmony·三方库
熊猫钓鱼>_>2 天前
移动端开发技术选型报告:三足鼎立时代的开发者指南(2026年2月)
android·人工智能·ios·app·鸿蒙·cpu·移动端
ITUnicorn2 天前
【HarmonyOS6】ArkTS 自定义组件封装实战:动画水杯组件
华为·harmonyos·arkts·鸿蒙·harmonyos6
晚霞的不甘2 天前
Flutter for OpenHarmony 构建简洁高效的待办事项应用 实战解析
flutter·ui·前端框架·交互·鸿蒙
廖松洋(Alina)2 天前
【收尾以及复盘】flutter开发鸿蒙APP之成就徽章页面
flutter·华为·开源·harmonyos·鸿蒙
廖松洋(Alina)2 天前
【收尾以及复盘】flutter开发鸿蒙APP之打卡日历页面
flutter·华为·开源·harmonyos·鸿蒙
廖松洋(Alina)2 天前
【收尾以及复盘】flutter开发鸿蒙APP之本月数据统计页面
flutter·华为·开源·harmonyos·鸿蒙