鸿蒙UI开发快速入门 —— part09: 应用级状态管理LocalStorage & AppStorage
1、说在前面的话
前面几个章节中介绍的装饰器(@State、@Props、@Link、@Provide、@Consume、@Observed、@ObjectLink)仅能在页面内,即一个组件树上共享状态变量。
如果开发者要实现应用级的,或者多个页面的状态数据共享,就需要用到应用级别的状态管理的概念。ArkTS根据不同特性,提供了多种应用状态管理的能力:
- LocalStorage:页面级UI状态存储,通常用于UIAbility内、页面间的状态共享。 
- AppStorage:特殊的单例LocalStorage对象,由UI框架在应用程序启动时创建,为应用程序UI状态属性提供中央存储; 
- PersistentStorage:持久化存储UI状态,通常和AppStorage配合使用,选择AppStorage存储的数据写入磁盘,以确保这些属性在应用程序重新启动时的值与应用程序关闭时的值相同; 
- Environment:应用程序运行的设备的环境参数,环境参数会同步到AppStorage中,可以和AppStorage搭配使用。 
下面我们分别来了解他们。
2、LocalStorage: 页面级UI状态存储
LocalStorage是页面级的UI状态存储,通过@Entry装饰器接收的参数可以在页面内共享同一个LocalStorage实例。LocalStorage也可以在UIAbility实例内,在页面间共享状态。
本小节重点介绍LocalStorage使用场景和相关的装饰器:@LocalStorageProp和@LocalStorageLink。
LocalStorage是ArkTS为构建页面级别状态变量提供存储的内存内“数据库”,它有以下特点:
- 应用程序可以创建多个LocalStorage实例,LocalStorage实例可以在页面内共享,也可以通过GetShared接口,实现跨页面、UIAbility实例内共享。 
- 组件树的根节点(即被@Entry装饰的@Component),可以被分配一个LocalStorage实例,此组件的所有子组件实例将自动获得对该LocalStorage实例的访问权限; 
- 被@Component装饰的组件最多可以访问一个LocalStorage实例和AppStorage,未被@Entry装饰的组件不可被独立分配LocalStorage实例,只能接受父组件通过@Entry传递来的LocalStorage实例。一个LocalStorage实例在组件树上可以被分配给多个组件。 
- LocalStorage中的所有属性都是可变的。 
- 应用程序决定LocalStorage对象的生命周期。当应用释放最后一个指向LocalStorage的引用时,比如销毁最后一个自定义组件,LocalStorage将被JS Engine垃圾回收。 
- LocalStorage创建后,命名属性的类型不可更改。后续调用Set时必须使用相同类型的值。 
- LocalStorage是页面级存储,GetShared接口仅能获取当前Stage通过windowStage.loadContent传入的LocalStorage实例,否则返回undefined。例子可见将LocalStorage实例从UIAbility共享到一个或多个视图。 
LocalStorage根据与@Component装饰的组件的同步类型不同,提供了两个装饰器:
- @LocalStorageProp:@LocalStorageProp装饰的变量和与LocalStorage中给定属性建立单向同步关系。 
- @LocalStorageLink:@LocalStorageLink装饰的变量和在@Component中创建与LocalStorage中给定属性建立双向同步关系。 
【tips:我们前面的文章学习了@Prop和@Link装饰器,在见到@LocalStorageProp和@LocalStorageLink装饰器后,会不会有一种熟悉感?】
在鸿蒙中,Prop单词表示单向同步,Link单词表示双向同步,在有@Prop和@Link的学习知识后,我们大致也能够猜测,@LocalStorageProp是单向的数据传递,@LocalStorageLink是双向的数据传递。
2.1、@LocalStorageProp装饰器
@LocalStorageProp(key)是和LocalStorage中key对应的属性建立单向数据同步,我们允许本地改变的发生,但是对于@LocalStorageProp,本地的修改永远不会同步回LocalStorage中,相反,如果LocalStorage给定key的属性发生改变,改变会被同步给@LocalStorageProp,并覆盖掉本地的修改。它有以下特点:
- 其允许装饰的变量类型为:Object、class、string、number、boolean、enum类型,以及这些类型的数组。 
- 装饰器参数必须为字符串,必填。 
- 必须指定初始值。 
在下面的示例中,CompA 组件和Child组件分别在本地创建了与storage的'PropA'对应属性的单向同步的数据,我们可以看到:
- CompA中对this.storProp1的修改,只会在CompA中生效,并没有同步回storage; 
- Child组件中,Text绑定的storProp2 依旧显示47。 
2.2、@LocalStorageLink装饰器
与前文所述的@LocalStorageProps类似,@LocalStorageLink的用法我们不再赘述,它与@LocalStorageProps的区别是,数据双向同步,我们将上文的demo改一下,将@LocalStorageProps改为@LocalStorageLink,我们将看到,两边的组件会同步更新。
3、AppStorage: 页面级UI状态存储
AppStorage是应用全局的UI状态存储,是和应用的进程绑定的,由UI框架在应用程序启动时创建,为应用程序UI状态属性提供中央存储。
和AppStorage不同的是,LocalStorage是页面级的,通常应用于页面内的数据共享。而AppStorage是应用级的全局状态共享,还相当于整个应用的“中枢”,持久化数据PersistentStorage和环境变量Environment都是通过和AppStorage中转,才可以和UI交互。
AppStorage使用场景和相关的装饰器:@StorageProp和@StorageLink。
对的,你没看错,也是@***Prop和@***Link,轻车熟路,我们只看Prop,Link就当成双向同步的版本类似用即可。
~上demo~
AppStorage是单例,它的所有API都是静态的,使用方法类似于LocalStorage对应的非静态方法。
4、结语
PersistentStorage与Environment后续章节继续讨论,请持续关注:
“鸿蒙UI开发快速入门 —— part10”
鸿蒙UI开发快速入门 —— part09: 应用级状态管理LocalStorage & AppStorage的更多相关文章
- Transform组件C#游戏开发快速入门
		Transform组件C#游戏开发快速入门大学霸 组件(Component)可以看作是一类属性的总称.而属性是指游戏对象上一切可设置.调节的选项,如图2-8所示.本文选自C#游戏开发快速入门大学霸 ... 
- HealthKit开发快速入门教程之HealthKit数据的操作
		HealthKit开发快速入门教程之HealthKit数据的操作 数据的表示 在HealthKit中,数据是最核心的元素.通过分析数据,人们可以看到相关的健康信息.例如,通过统计步数数据,人们可以知道 ... 
- HealthKit开发快速入门教程之HealthKit框架体系创建健康AppID
		HealthKit开发快速入门教程之HealthKit框架体系创建健康AppID HealthKit开发准备工作 在开发一款HealthKit应用程序时,首先需要讲解HealthKit中有哪些类,在i ... 
- HealthKit开发快速入门教程之HealthKit开发概述简介
		HealthKit开发快速入门教程之HealthKit开发概述简介 2014年6月2日召开的年度开发者大会上,苹果发布了一款新的移动应用平台,可以收集和分析用户的健康数据.该移动应用平台被命名为“He ... 
- Apple Watch开发快速入门教程
		Apple Watch开发快速入门教程 试读下载地址:http://pan.baidu.com/s/1eQ8JdR0 介绍:苹果为Watch提供全新的开发框架WatchKit.本教程是国内第一本A ... 
- 游戏控制杆OUYA游戏开发快速入门教程
		游戏控制杆OUYA游戏开发快速入门教程 1.2.2 游戏控制杆 游戏控制杆各个角度的视图,如图1-4所示,它的硬件规格是本文选自OUYA游戏开发快速入门教程大学霸: 图1-4 游戏控制杆各个角度的 ... 
- SpringBoot开发快速入门
		SpringBoot开发快速入门 目录 一.Spring Boot 入门 1.Spring Boot 简介 2.微服务 3.环境准备 1.maven设置: 2.IDEA设置 4.Spring Boot ... 
- WPF开发快速入门【7】WPF的拖放功能(Drag and Drop)
		概述 本文描述WPF的拖放功能(Drag and Drop). 拖放功能涉及到两个功能,一个就是拖,一个是放.拖放可以发生在两个控件之间,也可以在一个控件自己内部拖放.假设界面上有两个控件,一个Tre ... 
- abp vnext 开发快速入门 1 认识框架
		最近在做一个项目,用的框架是Abp vnext ,不是Abp, 我自己也是刚开始用这个框架来做项目,难免要查资料,这个框架官方有中文文档,可以到官网www.abp.io 去查看,国内也有一些写了相关的 ... 
- 三 Flask  web开发快速入门
		1:会话: from flask import Flask, url_for, request, render_template, session from werkzeug.utils import ... 
随机推荐
- skywalking/8.5部署
			制作镜像 OAP镜像 # cat oap/Dockerfile FROM apache/skywalking-oap-server:8.5.0-es7 # 时区修改为东八区 RUN apk add - ... 
- UEFI原理与编程(二)
			系统表 对UEFI应用程序和驱动程序开发人员来讲,系统表是最重要的数据结构之一,它是用户空间通往内核空间的通道.有了它,UEFI应用程序和驱动才可以访问UEFI内核.硬件资源和I/O设备. 1 在应用 ... 
- DBA面试资源合集(含Oracle、MySQL、Redis等)-墨天轮
			如今正值金九银十招聘季,众多企业开放大批岗位等待新力量的注入,各位DBA们,你们是否正在激情备战中? 作为企业数据化进程中十分重要的一环,DBA的职责越来越重要,作为高薪资岗位之一,应聘DBA的竞争也 ... 
- 墨天轮访谈 | IvorySQL王志斌—IvorySQL,一个基于PostgreSQL的兼容Oracle的开源数据库
			分享嘉宾:王志斌 瀚高IvorySQL产品经理 整理:墨天轮社区 导读 大家好,我是瀚高IvorySQL产品经理王志斌,IvorySQL是基于PostgreSQL的衍生开源项目. 我今天分享的内容主要 ... 
- nextjs 的函数,参数,属性装饰器的使用
			// 属性装饰器 const doc1:PropertyDecorator = (target:any,val: string | symbol) => { console.log(target ... 
- amfe-flexible 包设置rem的基本值 vue 移动端适配方案
			下载 安装 :npm i -S amfe-flexible gw:GitHub - amfe/lib-flexible: 可伸缩布局方案 下载 2 个第三方包即可实现移动端适配 amfe-flexib ... 
- 38. data为什么是一个函数
			vue中的data为什么是返回对象的函数,而不是直接使用对象形式 : 我们复用组件的时候,要求每一份data数据之间是独立的,不能互相影响,如果写成对象的形式所有的组件使用一份data数据 ,如果使用 ... 
- 13 Multi-Head Self-Attention(从空间角度解释为什么做多头)
			博客配套视频链接: https://space.bilibili.com/383551518?spm_id_from=333.1007.0.0 b 站直接看 配套 github 链接:https:// ... 
- Kubernetes 升级不弃 Docker:KubeKey 的丝滑之道
			作者:尹珉,KubeSphere Ambaasador&Contributor,KubeSphere 社区用户委员会杭州站站长. 引言 随着 Kubernetes 社区的不断发展,即将迎来 K ... 
- Kubernetes CNI 插件选型和应用场景探讨
			作者:马伟,青云科技容器顾问,云原生爱好者,目前专注于云原生技术,云原生领域技术栈涉及 Kubernetes.KubeSphere.KubeKey 等. 本文介绍容器环境常见网络应用场景及对应场景的 ... 
