【HarmonyOS NEXT】数据持久化 - 用户首选项

用户首选项(Preference)为应用提供 key-value 键值型的数据处理能力,支持应用持久化轻量型数据。

一、用户首选项完成数据持久化的过程

首先创建首选项实例,一个应用内部可以创建多个首选项实例,这样可以在应用的不同模块用不同的实例,避免相互之间干扰。每一个用户首选项的实例都会对应应用隔离沙箱内的一个持久化文件,当我们去调用用户首选项相关接口进行数据读写的时候,它就会去操作那个持久化文件,从而实现对数据持久化以及读写操作。

请添加图片描述

二、用户首选项具体使用步骤

  1. 导入首选项模块

    import dataPreference from '@ohos.data.preferences'
    
  2. 获取首选项实例,读取指定文件

    dataPreferences.getPreferences(this.getContext(), 'MyAppPreferences')
      .then(preferences => {
        // 获取成功
      })
      .catch((error: Error) => {
       // 获取失败
      })
    
    • this.getContext():上下文,也就是 UIAbilityContext
    • MyAppPreferences:是 Preferences 实例名称

    注:获取首选项实例肯定要读写磁盘上的持久化文件,这是一个 I/O 操作,比较耗时,所以它是一个异步的,因此,调用这个方法不会立刻返回 Preferences 对象,而是返回一个 Promise,所以会发现依然调用了 then 和 catch。

  3. 数据操作

    // 写入数据,如果已经存在则会覆盖,可利用 .has() 判断是否存在
    preferences.put('key', value)
      .then(() => preferences.flush())   // 刷到磁盘
      .catch((error: Error) => {})       // 处理异常 
    
    // 删除数据
    preferences.delete('key')
      .then(() => {})
      .catch((error: Error) => {})
    
    // 查询数据
    preferences.get('key', 'defaultValue')
      .then(value => console.log('查询成功'))
      .catch((error: Error) => console.log('查询失败'))
    

    说明:

    • Key 为 string 类型,要求非空且长度不超过80字节
    • Value 可以是 string、number、boolean 及以上类型数组,大小不超过8192字节
    • 数据量建议不超过一万条
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

吴同学是个程序员

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值