【鸿蒙 HarmonyOS】数据持久化

打印 上一主题 下一主题

主题 1398|帖子 1398|积分 4209

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
一、数据持久化先容

数据持久化是将内存数据(内存是临时的存储空间),通过文件或数据库的形式保存在设备中。
HarmonyOS提供两种数据持久化方案:
1.1、用户首选项(Preferences):

通常用于保存应用的配置信息。数据通过文本的形式保存在设备中,应用使用过程中会将文本中的数据全量加载到内存中,所以访问速度快、服从高,但不得当需要存储大量数据的场景。
1.2、数据库:

键值型数据库(KV-Store):一种非关系型数据库,其数据以“键值”对的形式举行组织、索引和存储,此中“键”作为唯一标识符。得当很少数据关系和业务关系的业务数据存储,同时因其在分布式场景中低沉相识决数据库版本兼容问题的复杂度,和数据同步过程中辩说办理的复杂度而被广泛使用。相比于关系型数据库,更容易做到跨设备跨版本兼容。
关系型数据库(RelationalStore):一种关系型数据库,以行和列的形式存储数据,广泛用于应用中的关系型数据的处理,包罗一系列的增、删、改、查等接口,开发者也可以运行自己定义的SQL语句来满足复杂业务场景的需要。
二、通过用户首选项实现数据持久化

使用场景:用户首选项为应用提供Key-Value键值型的数据处理本领,支持应用持久化轻量级数据,并对其修改和查询。

   说明:
  ①Key键为string类型,要求非空且长度不超过80个字节。
  ②Value可以是string、number、boolean及以上类型数组,大小不超过8192字节
  ③数据量建议不超过一万条
  

2.1、基本案例

2.1.1、案例代码

  1. @Entry
  2. @Component
  3. struct Index {
  4.   @State message: string = '页面列表'
  5.   @State showPanel: boolean = false
  6.   @Provide fontSize: number = 16
  7.   build() {
  8.     Column(){
  9.       // 顶部标题
  10.       this.Title()
  11.       // 导航列表
  12.       this.RouterList()
  13.       // 字体修改面板
  14.       if(this.showPanel){
  15.         IndexFontSizePanel()
  16.           .transition({
  17.             translate: { y: 115 }
  18.           })
  19.       }
  20.     }
  21.     .width('100%')
  22.     .height('100%')
  23.   }
  24.   @Builder Title(){
  25.     Row() {
  26.       Text(this.message)
  27.         .fontSize(50)
  28.         .fontWeight(FontWeight.Bold)
  29.         .height(80)
  30.       Image($r('app.media.ic_public_settings'))
  31.         .width(30)
  32.         .onClick(() => {
  33.           animateTo({ duration: 500, curve: Curve.EaseOut }, () => this.showPanel = !this.showPanel)
  34.         })
  35.     }
  36.     .justifyContent(FlexAlign.SpaceAround)
  37.     .width('100%')
  38.   }
  39.   @Builder RouterList() {
  40.     List({ space: 15 }) {
  41.       ForEach(
  42.         ['导航','屏幕','图片','图书','书架'],
  43.         (item,index) => {
  44.           ListItem() {
  45.             Row(){
  46.               Text((index+1) + '.')
  47.                 .fontSize(this.fontSize)
  48.                 .fontColor(Color.White)
  49.               Blank()
  50.               Text(item)
  51.                 .fontSize(this.fontSize)
  52.                 .fontColor(Color.White)
  53.             }
  54.             .width('90%')
  55.             .padding(12)
  56.             .backgroundColor('#38f')
  57.             .borderRadius(20)
  58.             .shadow({radius: 6, color: '#4F000000', offsetX: 2, offsetY: 4})
  59.           }
  60.         }
  61.       )
  62.     }
  63.     .layoutWeight(1)
  64.     .alignListItem(ListItemAlign.Center)
  65.     .width('100%')
  66.   }
  67. }
  68. @Component
  69. struct IndexFontSizePanel {
  70.   @Consume fontSize: number
  71.   fontSizLabel: object = {
  72.     14: '小',
  73.     16: '标准',
  74.     18: '大',
  75.     20: '特大',
  76.   }
  77.   build() {
  78.     Column() {
  79.       Text(this.fontSizLabel[this.fontSize]).fontSize(20)
  80.       Row({ space: 5 }) {
  81.         Text('A').fontSize(14).fontWeight(FontWeight.Bold)
  82.         Slider({
  83.           min: 14,
  84.           max: 20,
  85.           step: 2,
  86.           value: this.fontSize
  87.         })
  88.           .showSteps(true)
  89.           .trackThickness(6)
  90.           .layoutWeight(1)
  91.           .onChange(val => {
  92.             // 修改字体大小
  93.             this.fontSize = val
  94.           })
  95.         Text('A').fontSize(20).fontWeight(FontWeight.Bold)
  96.       }.width('100%')
  97.     }
  98.     .width('100%')
  99.     .padding(15)
  100.     .backgroundColor('#fff1f0f0')
  101.     .borderRadius(20)
  102.   }
  103. }
复制代码
2.1.2、案例结果:


   案例说明:
  这是一个页面列表展示案例,点击右上角的设置按钮,底部会弹出字体修改面板,字体有4个不同的大小(小/尺度/大/特大),当点击滑动条可以修改字体大小
  目前更改了滑动条的字体大小数据是保存在内存的,关闭页面后再进来数据体现默认大小,如今是想通过用户首选项实现数据持久化,持久化保存设置的字体大小
  2.2、详细实现

2.2.1、定义用户首选项操作文件

  1. import preferences from '@ohos.data.preferences';
  2. class PreferencesUtil{
  3.   prefMap: Map<string, preferences.Preferences> = new Map()
  4.   async loadPreference(context, name: string){
  5.     try { // 加载preferences
  6.       let pref = await preferences.getPreferences(context, name)
  7.       this.prefMap.set(name, pref)
  8.       console.log('testTag', `加载Preferences[${name}]成功`)
  9.     } catch (e) {
  10.       console.log('testTag', `加载Preferences[${name}]失败`, JSON.stringify(e))
  11.     }
  12.   }
  13.   async putPreferenceValue(name: string, key: string, value: preferences.ValueType){
  14.     if (!this.prefMap.has(name)) {
  15.       console.log('testTag', `Preferences[${name}]尚未初始化!`)
  16.       return
  17.     }
  18.     try {
  19.       let pref = this.prefMap.get(name)
  20.       // 写入数据
  21.       await pref.put(key, value)
  22.       // 刷盘
  23.       await pref.flush()
  24.       console.log('testTag', `保存Preferences[${name}.${key} = ${value}]成功`)
  25.     } catch (e) {
  26.       console.log('testTag', `保存Preferences[${name}.${key} = ${value}]失败`, JSON.stringify(e))
  27.     }
  28.   }
  29.   async getPreferenceValue(name: string, key: string, defaultValue: preferences.ValueType){
  30.     if (!this.prefMap.has(name)) {
  31.       console.log('testTag', `Preferences[${name}]尚未初始化!`)
  32.       return
  33.     }
  34.     try {
  35.       let pref = this.prefMap.get(name)
  36.       // 读数据
  37.       let value = await pref.get(key, defaultValue)
  38.       console.log('testTag', `读取Preferences[${name}.${key} = ${value}]成功`)
  39.       return value
  40.     } catch (e) {
  41.       console.log('testTag', `读取Preferences[${name}.${key} ]失败`, JSON.stringify(e))
  42.     }
  43.   }
  44. }
  45. const preferencesUtil = new PreferencesUtil()
  46. export default preferencesUtil as PreferencesUtil
复制代码
2.2.2、将数据加载到Preferences实例,用于数据操作。

放入应用启动时来操作,找到EntryAbility文件,在onCreate应用创建时,加载Preferences实例

2.2.3、Index页面使用

第一步:一进入首页就举行读取
使用页面生命周期aboutToAppear来执行

第二步:修改字体大小时写入Preferences

   末了:
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

大连全瓷种植牙齿制作中心

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表