0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

鸿蒙OS开发实例:【应用状态变量共享】

jf_46214456 来源:jf_46214456 作者:jf_46214456 2024-04-03 15:09 次阅读

平时在开发的过程中,我们会在应用中共享数据,在不同的页面间共享信息。虽然常用的共享信息,也可以通过不同页面中组件间信息共享的方式,但有时使用应用级别的状态管理会让开发工作变得简单。

根据不同的使用场景,ArkTS提供了以下几种应用状态管理的能力:

  • LocalStorage :使用范围在同一页面,页面与卡片和页面与UIAbility内部,负责UI状态存储。
  • AppStorage :运行时存储,保存在内存中,应用范围全局共享,提供统一的存储供所有页面访问。
  • PersistentStorage :持久化存储,保存在硬盘上,在应用退出或重启后,数据依旧保留。

下面通过简单的程序示例,熟悉一下这三种用法。其中示例程序中包含了以下主要文件:

image.png

一、LocalStorage

页面级的UI状态存储,同一个页面共享同一个LocalStorage,不同的页面都可以绑定对应的LocalStorage。最常用的就是更新服务卡片和跨页面的信息传递。

场景一:更新服务卡片

服务卡片中被@Entry装饰的@Component,可以被分配一个LocalStorage实例,在组件内部,通过@LocalStorageProp装饰器定义本地变量,并绑定到对应组件上。更新卡片时,先定义一个包含了和LocalStorageProp属性同名的参数并放到formBindingData中,然后通过formProvider.updateForm函数,就可以更新服务卡片了。

我们要在EntryFormAbility.ets中通过传递LocalStorage改变服务卡片中的默认Hello的文本标签为当前时间。

实践步骤:前请熟悉开发文档开发知识更新库[docs.qq.com/doc/DUmN4VVhBd3NxdExK]

搜狗高速浏览器截图20240326151344.png

1.修改服务卡片布局文件,文件开头添加:

或者添加mau123789是v直接领
let storage = new LocalStorage();复制

并为Entry增加参数storage。

例如,WidgetCard.ets,默认:

@Entry
@Component
struct WidgetCard {
...复制

改之后:

let storage = new LocalStorage();
@Entry(storage)
@Component
struct WidgetCard {
...复制

2.在EntryFormAbility.ets中,用装饰器LocalStorageProp定义本地变量,装饰器的参数必须要和formBindingData中的属性名称相同。

例如,在接收方服务卡片中定义如下:

@LocalStorageProp('localprop') localValue: string = 'Hello';复制

image.png

卡片标签默认显示了Hello。

在发送方EntryFormAbility.ts文件的onFormEvent函数里:

onFormEvent(formId, message) {
  let date = new Date();
  let str = date.getHours().toString().padStart(2, '0') + ':' +  date.getMinutes().toString().padStart(2, '0') + ':' + date.getSeconds().toString().padStart(2, '0')
  let formData = {
    'localprop': 'Time: ' + str,
  };
  let formInfo = formBindingData.createFormBindingData(formData)
  formProvider.updateForm(formId, formInfo).then((data) = > {
    console.info('FormAbility updateForm success.' + JSON.stringify(data));
  }).catch((error) = > {
    console.error('FormAbility updateForm failed: ' + JSON.stringify(error));
  })
}复制

formData对象里包含了名称为localprop的键值,它通过formBindingData由formProvider传递给服务卡片,服务卡片接收到该对象后,就自动把该对象赋值给LocalStorage,相应的LocalStorageProp也自动跟着刷新。

这个动作是通过点击卡片上的update按钮,触发了postCardAction事件从而调用了onFormEvent函数,执行结果如下:

image.png

场景二:跨页面的信息传递

在页面初次加载时,可以在EntryAbility.ts中传递一个LocalStorage对象给要打开的页面。

我们打算在index.ets页面加载的时候,在EntryAbility中传递一个包含abilitycount值为1的Storage,页面加载后界面显示该值。

实践步骤:

1.在EntryAbility.ts中定义一个LocalStorage类型的变量,里面包含abilitycount属性。

export default class EntryAbility extends UIAbility {
  storage: LocalStorage = new LocalStorage({
    'abilitycount': 1
  });复制

在onWindowStageCreate函数中,将默认的:

windowStage.loadContent('pages/Index', (err, data) = > {复制

改为传递参数的方式,如下:

windowStage.loadContent('pages/Index', this.storage);复制

2.在页面端Index.ets中,文件开头添加代码来获取共享的LocalStorage。

let storage = LocalStorage.GetShared()复制

在结构体内部,通过装饰器LocalStorageProp加同样属性名称作为参数,定义一个变量。

@LocalStorageProp('abilitycount') abilityCount: number = 0;复制

这样名为abilitycount的值就通过LocalStorage传递到页面了,本地默认的值0变为了传递过来的值1。

下图中LocalStorage的值就是页面打开时显示的传递过来的值。

image.png

二、AppStorage

全局的UI状态存储,在运行时阶段可以在不同的页面间共享信息。

我们通过在Index.ets页面创建一个变量放到AppStorage中,然后分别在First.ets页面和Second.ets页面访问和修改。

实践步骤:

1.首先在Index.ets中,通过AppStorage定义一个属性。

AppStorage.SetOrCreate('appcount', 10);复制

然后,在组件结构体中使用StorageProp装饰器定义一个变量,参数为之前定义的appcount属性。

@Entry()
@Component
struct Index {

  @StorageProp('appcount') appValue: number = 0;复制

2.在First.ets页面中,通过StorageProp定义一个appValue变量,关联到appcount属性上。

struct First {
  @StorageProp('appcount') appValue: number = 0;复制

在本地修改时,把用户输入的值写入AppStorage,使用如下语句:

AppStorage.Set('appcount', this.textApp);复制

Second.ets页面与First.ets页面功能完全相同,主要显示AppStorage在不同页面显示和修改的效果。

如下图,主页面、第一个页面和第二个页面初始状态下,读取到的AppStorage中的同一个属性的值都是10。

image.png

在第一个页面First.ets中把AppStorage中的属性值改为11,我们发现在主页面Index.ets和Second.ets中,对应的属性值都发生了变化。

image.png

同样,在第二个页面Second.ets中把AppStorage中的属性值改为12,我们发现在Index.ets和First.ets中,对应的属性值也都变为了改后的值。

image.png

如上测试,我们发现的确可以通过AppStorage在不同页面间共享数据。

三、PersistentStorage

持久化存储UI状态。保存在PersistentStorage中的数据,即使应用退出了,对应的值依然会保留,不是在内存中,而是存储在固定存储介质上的。

我们通过在Index.ets页面创建一个属性放到PersistentStorage中,然后分别在First.ets页面和Second.ets页面进行修改,然后再重启应用观察结果。

实践步骤:

1.首先在Index.ets中,在PersistentStorage里定义一个属性。

PersistentStorage.PersistProp('persistentcount', 100);复制

然后在组件结构体中,通过装饰器StorageProp定义一个属性为persistentcount的变量。

@Entry()
@Component
struct Index {
  @StorageProp('persistentcount') persistentValue: number = 0;复制

2.在First.ets页面中,我们通过装饰器StorageProp定义一个变量绑定persistentcount属性。

@Entry
@Component
struct First {
  @StorageProp('persistentcount') persistentValue: number = 0;复制

通过输入框输入新值改变原来存储在PersistentStorage的内容。

AppStorage.Set('persistentcount', this.textPersistent);复制

演示效果如下图,Index.ets页面,在初始时AppStorage和PersistentStorage中的对应属性值分别是10和100,在First.ets页面中,我们分别改为11和111。

image.png

关闭应用,然后重新打开,如下图所示,AppStorage中的属性值恢复为了10,PersistentStorage中的属性值依旧是111,是改后的值。这证明了PersistentStorage有持续化存储的作用。

image.png

四、总结

通过这次实践,熟悉了不同的状态变量在应用中的不同应用范围,选用合适的状态变量会让应用开发简单快捷,本地页面内部使用LocalStorage保存数据,应用页面间通过AppStorage传递信息,PersistentStorage可以持久化存储数据信息。

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 变量
    +关注

    关注

    0

    文章

    596

    浏览量

    28113
  • 鸿蒙OS
    +关注

    关注

    0

    文章

    151

    浏览量

    4281
收藏 人收藏

    评论

    相关推荐

    鸿蒙开发教程-管理组件状态

    跨组件层级双向同步状态是指@Provide修饰的状态变量自动对提供者组件的所有后代组件可用,后代组件通过使用@Consume装饰的变量来获得对提供的状态变量的访问。
    的头像 发表于 01-22 21:46 783次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>开发</b>教程-管理组件<b class='flag-5'>状态</b>

    HarmonyOS实践之应用状态变量共享

    PersistentStorage 有持续化存储的作用。 四、总结 通过这次实践,熟悉了不同的状态变量在应用中的不同应用范围,选用合适的状态变量会让应用开发简单快捷,本地页面内部使用 LocalStorage 保存数据
    发表于 12-27 09:48

    Harmony 鸿蒙页面级变量状态管理

    组件实例时,可以通过变量名显式指定@State状态变量的初始值。 示例: 在下面的示例中: 用户定义的组件MyComponent定义了@State状态变量count和title。如果c
    发表于 01-24 20:04

    系统的状态变量分析

    系统的状态变量分析:状态变量法具有以下主要优点:(1) 可以有效地提供系统内部的信息,使人们较为容易地处理那    &
    发表于 09-10 11:38

    典型的状态变量滤波器与两个陷波状态变量设计比较

    具有两个反相积分器的状态变量滤波器的通常示意图是众所周知的。奇怪的是,输入信号几乎总是连接到 U1 的负输入。图 1是一个例子IN = 1kHz,Q = 5。图 1 典型的状态变量滤波器该电路以其
    发表于 10-11 07:00

    OpenHarmony状态变量更改通知:@Watch装饰器

    @Watch应用于对状态变量的监听。如果开发者需要关注某个状态变量的值是否改变,可以使用@Watch为状态变量设置回调函数。 说明: 从API version 9开始,该装饰器支持在A
    发表于 10-31 17:45

    动态电路的状态变量分析

    动态电路的状态变量分析􀂄 7.1 电路的状态状态变量􀂄 7.2 状态方程及其列写􀂄 7.3
    发表于 12-04 18:01 0次下载
    动态电路的<b class='flag-5'>状态变量</b>分析

    带通状态变量滤波器电路图

    带通状态变量滤波器电路图
    发表于 03-30 09:10 777次阅读
    带通<b class='flag-5'>状态变量</b>滤波器电路图

    二阶状态变量滤波器电路图

    二阶状态变量滤波器电路图
    发表于 03-30 09:17 942次阅读
    二阶<b class='flag-5'>状态变量</b>滤波器电路图

    通用状态变量滤波器电路图

    通用状态变量滤波器电路图
    发表于 03-30 09:36 828次阅读
    通用<b class='flag-5'>状态变量</b>滤波器电路图

    状态变量滤波器,状态变量滤波器原理是什么?

    状态变量滤波器,状态变量滤波器原理是什么? 状态变量滤波器,又称多态变量滤波器,它可以分别从不同的点同时输出高通、带通、低通等,且
    发表于 03-24 14:24 6285次阅读

    低失真、状态变量式2相振荡电路

    低失真、状态变量式2相振荡电路 电路的功能 用于音响设备的放大
    发表于 05-14 14:54 1202次阅读
    低失真、<b class='flag-5'>状态变量</b>式2相振荡电路

    时域离散系统的基本网络结构与状态变量分析法

    关于DSP的很好的资料哦,很好的用品,比较详细,第5章__时域离散系统的基本网络结构与状态变量分析法]
    发表于 12-23 11:08 0次下载

    数字编程状态变量滤波器

    状态变量滤波器具有吸引力的一项特点是其参数(增益、截止频率和Q)可以单独调节。我们可以利用这种属性以数字方式控制这些参数。
    发表于 03-22 17:43 2次下载
    数字编程<b class='flag-5'>状态变量</b>滤波器

    开发者说】HarmonyOS实践之应用状态变量共享

    】,即可获得投稿渠道。期待你们的分享~ 平时在开发的过程中,我们会在应用中共享数据,在不同的页面间共享信息。虽然常用的共享信息,也可以通过不同页面中组件间信息
    的头像 发表于 12-26 21:20 422次阅读
    【<b class='flag-5'>开发</b>者说】HarmonyOS实践之应用<b class='flag-5'>状态变量</b><b class='flag-5'>共享</b>