当前位置:   article > 正文

【鸿蒙 HarmonyOS 4.0】数据持久化_鸿蒙数据持久化

鸿蒙数据持久化

一、数据持久化介绍

数据持久化是将内存数据(内存是临时的存储空间),通过文件或数据库的形式保存在设备中。

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

最后:声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】

推荐阅读
相关标签