HarmonyOS持久化存储数据Preference

Preference首选项

  • 首选项:首选项为应用提供Key-Value键值型的数据处理能力,支持应用持久化轻量级数据,并对其修改和查询。数据存储形式为键值对,键的类型为字符串型,值的存储数据类型包括数字型、字符型、布尔型以及这3种类型的数组类型。

Demo记录APP首次启动

  • 通常用于首次启动后弹出隐私协议弹窗,然后记录后,下次启动不在弹窗。
  • 调用页面
ts 复制代码
import SpUtils from './utils/SpUtils'

@Entry
@Component
struct PagePreference {
  @State msg: string = ""

  onPageShow(): void {
    this.msg = "当前数据" + SpUtils.isFirst()
  }

  build() {
    Column() {


      Button("保存数据")
        .id('PagePreferenceHelloWorld')
        .margin({ top: 20 })
        .fontSize(20)
        .fontWeight(FontWeight.Bold)
        .onClick(() => {
          SpUtils.setFirst()
          this.msg = "保存数据"
        })

      Button("获取数据")
        .id('PagePreferenceHelloWorld')
        .margin({ top: 20 })
        .fontSize(20)
        .fontWeight(FontWeight.Bold)
        .onClick(() => {
          this.msg = "获取数据" + SpUtils.isFirst()
        })

      Button("清空数据")
        .id('PagePreferenceHelloWorld')
        .margin({ top: 20 })
        .fontSize(20)
        .fontWeight(FontWeight.Bold)
        .onClick(() => {
          this.msg = "清空数据"
          SpUtils.clearData()
        })

      Text(this.msg)
        .fontSize(25)
        .margin({ top: 20 })

    }
    .height('100%')
    .width('100%')
  }
}
  • 工具类SpUtils
ts 复制代码
import preferences from '@ohos.data.preferences'

export default class SpUtils {
  private static KEY_DATA = "key_data"
  private static SP_NAME = "data"
  private static sp: preferences.Preferences = preferences.getPreferencesSync(getContext(this), {
    name: SpUtils.SP_NAME
  })

  //设置启动状态
  static setFirst() {
    SpUtils.sp.putSync(SpUtils.KEY_DATA, false)
    SpUtils.sp.flush()
  }


  //是否首次启动
  static isFirst(): boolean {
    let data = SpUtils.sp.getSync(SpUtils.KEY_DATA, true) as boolean
    return data
  }

  //清空该表中的所有数据
  static clearData() {
    SpUtils.sp.clearSync()
    SpUtils.sp.flush()
  }
}
相关推荐
木斯佳5 小时前
HarmonyOS 6实战::多组件嵌套场景下,自动化测试覆盖复杂交互实践
华为·交互·harmonyos
键盘鼓手苏苏10 小时前
Flutter 三方库 pip 的鸿蒙化适配指南 - 实现标准化的画中画(Picture-in-Picture)模式、支持视频悬浮窗与多任务并行交互
flutter·pip·harmonyos
左手厨刀右手茼蒿10 小时前
Flutter 组件 sheety_localization 的适配 鸿蒙Harmony 实战 - 驾驭在线协作式多语言管理、实现鸿蒙端动态词条下发与全球化敏捷发布方案
flutter·harmonyos·鸿蒙·openharmony·sheety_localization
见山是山-见水是水10 小时前
鸿蒙flutter第三方库适配 - 路由书签应用
flutter·华为·harmonyos
火柴就是我10 小时前
记录一些跨平台开发需要的鸿蒙知识
flutter·harmonyos
小雨青年11 小时前
鸿蒙 HarmonyOS 6 | 空间音频技术实战指南
华为·音视频·harmonyos
Huanzhi_Lin12 小时前
鸿蒙NEXT-HelloWorld
华为·harmonyos·arkts·arkui·ets
特立独行的猫a13 小时前
使用 vcpkg 为鸿蒙(HarmonyOS / OHOS)下载与安装三方库实践指南
华为·harmonyos·openharmony·vcpkg·三方库·鸿蒙pc
音视频牛哥13 小时前
HarmonyOS NEXT系统RTSP、RTMP超低延迟直播播放器全面解析
华为·harmonyos·鸿蒙rtmp播放器·鸿蒙rtsp播放器·纯血鸿蒙rtsp播放器·harmonyos rtsp·harmonyos rtmp
音视频牛哥13 小时前
国产化浪潮下,鸿蒙NEXT低延迟RTSP|RTMP直播播放器的破局之路
harmonyos·大牛直播sdk·鸿蒙rtmp播放器·鸿蒙rtsp播放器·鸿蒙next rtsp播放器·鸿蒙next rtmp播放器·纯血鸿蒙rtsp播放器