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

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

相关推荐
kirk_wang3 天前
Flutter GPUImage 库在鸿蒙平台的 GPU 图像滤镜适配实战
flutter·移动开发·跨平台·arkts·鸿蒙
柒儿吖4 天前
命令行critic.sh在开源鸿蒙PC平台的实现解析
鸿蒙·命令行
kirk_wang4 天前
Flutter `flutter_statusbarcolor_ns` 在 OpenHarmony 平台的状态栏颜色适配实践
flutter·移动开发·跨平台·arkts·鸿蒙
kirk_wang4 天前
Flutter 三方库在 OHOS 平台的适配实践:以 flutter_test_lib 为例
flutter·移动开发·跨平台·arkts·鸿蒙
kirk_wang4 天前
Flutter 三方库在 OHOS 平台的适配实践
flutter·移动开发·跨平台·arkts·鸿蒙
m0_637146934 天前
鸿蒙技术实测:ArkTS 语言深度解读
鸿蒙·鸿蒙系统
大土豆的bug记录6 天前
鸿蒙实现自定义类似活体检测功能
数码相机·华为·harmonyos·鸿蒙
hahjee6 天前
命令行参数解析利器:gnuflag在OpenHarmony PC上的完整适配实战
开源·鸿蒙
kirk_wang6 天前
Flutter 三方库 `flutter_phone_direct_caller` 在 OpenHarmony 平台的适配实战
flutter·移动开发·跨平台·arkts·鸿蒙
hahjee6 天前
Go编写的ANSI终端颜色和样式控制库在OpenHarmony PC上的完整适配实战
开发语言·后端·鸿蒙