鸿蒙开发-UI-应用-状态管理

本文介绍了鸿蒙开发中的状态管理,包括页面级的LocalStorage、应用全局的AppStorage、持久化存储的PersistentStorage以及环境查询的Environment。重点讲解了如何通过装饰器管理应用状态,实现UI组件之间的状态同步。
摘要由CSDN通过智能技术生成

鸿蒙开发-序言

鸿蒙开发-工具

鸿蒙开发-初体验

鸿蒙开发-运行机制

鸿蒙开发-运行机制-Stage模型

鸿蒙开发-UI

鸿蒙开发-UI-组件

鸿蒙开发-UI-组件-状态管理


前言

上文学习了鸿蒙开发的组件状态,详细分析状态变量与UI渲染交互逻辑,本文将学习鸿蒙开发应用的状态管理。

一、管理应用拥有的状态

上文分享的组件状态管理中装饰器仅能在页面内,即一个组件树上共享状态变量。如果要实现应用级的,或者多个页面的状态数据共享,就需要用到应用级别的状态管理的概念。管理应用拥有状态的装饰器支持应用级别的状态管理,可以观察不同页面,甚至不同UIAbility的状态变化,是应用内全局的状态管理。

1.页面级UI状态存储 LocalStorage

LocalStorage是页面级的UI状态存储,通过@Entry装饰器接收的参数可以在页面内共享同一个LocalStorage实例。LocalStorage也可以在UIAbility实例内,在页面间共享状态。

基本概念:

@LocalStorageProp

建立LocalStorage和自定义组件的联系,使用@LocalStorageProp(key)装饰组件内的变量,key标识了LocalStorage的属性。当自定义组件初始化的时候,@LocalStorageProp(key)装饰的变量会通过给定的key,绑定LocalStorage对应的属性,完成初始化。考虑到组初始化前LocalStorage实例中无法保证存在绑定属性,支持本地初始化。@LocalStorageProp(key)是和LocalStorage中key对应的属性建立单向数据同步,本地的修改永远不会同步回LocalStorage中,如果LocalStorage给定key的属性发生改变,改变会被同步给@LocalStorageProp,并覆盖掉本地的修改。

@LocalStorageProp初始化规则图示

使用场景:

@LocalStorageLink

@LocalStorageLink(key)是和LocalStorage中key对应的属性建立双向数据同步。

 @LocalStorageLink初始化规则图示

使用场景:

2.应用全局的UI状态存储 AppStorage

AppStorage是应用全局的UI状态存储,是和应用的进程绑定的,由UI框架在应用程序启动时创建,为应用程序UI状态属性提供中央存储。

@StorageProp

@StorageProp初始化规则图示

@StorageLink

@StorageLink初始化规则图示

3.持久化存储UI状态 PersistentStorage

PersistentStorage是应用程序中的可选单例对象。此对象的作用是持久化存储选定的AppStorage属性,以确保这些属性在应用程序重新启动时的值与应用程序关闭时的值相同。PersistentStorage将选定的AppStorage属性保留在设备磁盘上。应用程序通过API,以决定哪些AppStorage属性应借助PersistentStorage持久化。UI和业务逻辑不直接访问PersistentStorage中的属性,所有属性访问都是对AppStorage的访问,AppStorage中的更改会自动同步到PersistentStorage。

PersistentStorage和AppStorage中的属性建立双向同步。应用开发通常通过AppStorage访问PersistentStorage,另外还有一些接口可以用于管理持久化属性,但是业务逻辑始终是通过AppStorage获取和设置属性的。

 PersistProp初始化流程:

使用场景:

  • 触发点击事件后:
  1. 状态变量@StorageLink('aProp') aProp改变,触发Text组件重新刷新。
  2. @StorageLink装饰的变量是和AppStorage中建立双向同步的,所以@StorageLink('aProp') aProp的变化会被同步回AppStorage中。
  3. AppStorage中“aProp”属性的改变会同步到所有绑定该“aProp”的单向或者双向变量,在本示例中没有其他的绑定“aProp”的变量。
  4. 因为“aProp”对应的属性已经被持久化,所以在AppStorage中“aProp”的改变会触发PersistentStorage将新的改变写入本地磁盘。
  • 后续启动应用:
  1. 在Index组件里,@StorageLink绑定的“aProp”为PersistentStorage写入AppStorage中的值,即为上一次退出引用存入的值。
  2. 将在PersistentStorage查询到的值写入AppStorage中。
  3. 执行PersistentStorage.PersistProp('aProp', 47),在首先查询在PersistentStorage本地文件查询“aProp”属性,成功查询到。

4.设备环境查询 Environment

Environment是ArkUI框架在应用程序启动时创建的单例对象。

使用场景:

注:PersistentStorage、Environment都是通过AppStorage与组件中绑定变量交互的,本身不直接交互


总结

本文学习了鸿蒙开发应用的状态管理,与上文组件状态管理构成整个ArkUI框架提供的状态管理机制,其核心就是UI是状态的运行结果。下文学习UI渲染控制。

  • 24
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值