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

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

相关推荐
伍哥的传说12 小时前
鸿蒙系统(HarmonyOS)应用开发之手势锁屏密码锁(PatternLock)
前端·华为·前端框架·harmonyos·鸿蒙
伍哥的传说1 天前
鸿蒙系统(HarmonyOS)应用开发之实现电子签名效果
开发语言·前端·华为·harmonyos·鸿蒙·鸿蒙系统
HarmonyOS小助手12 天前
京东正式开源Taro on HarmonyOS C-API 版本,为鸿蒙应用跨端开发提供高性能框架
harmonyos·鸿蒙·harmonyos next·harmonyos 5.0·鸿蒙5·鸿蒙生态
在人间耕耘13 天前
鸿蒙云函数与云数据库开发实践
鸿蒙
呆dai~15 天前
基于原生能力的键盘控制
harmonyos·鸿蒙
知然19 天前
鸿蒙 Native API 的封装库 h2lib_arkbinder
c++·arkts·鸿蒙
Francek Chen24 天前
【华为Pura80系列】鸿蒙生态再升级:Pura 80 系列影像突破,WATCH 5 开启智能手表新纪元
华为·harmonyos·鸿蒙·智能手表·pura80·watch 5
编号:051724 天前
【HarmonyOS 5.0】开发实战:从UI到Native全解析
鸿蒙·devecostudio·harmonyos5.0
萌虎不虎1 个月前
【鸿蒙在 ETS (Extendable TypeScript) 中创建多级目录或文件,可以使用鸿蒙的文件系统 API】
鸿蒙
颜颜yan_1 个月前
【HarmonyOS5】UIAbility组件生命周期详解:从创建到销毁的全景解析
架构·harmonyos·鸿蒙·鸿蒙系统