arkts状态管理使用(@State、@Prop、@Link、@Provide、@Consume、@objectLink和@observed)

本文主要是介绍arkts状态管理使用(@State、@Prop、@Link、@Provide、@Consume、@objectLink和@observed),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、状态管理

1.在声明式UI中,是以状态驱动视图更新:

①状态(State):指驱动视图更新的数据(被装饰器标记的变量)

②视图(View):基于UI描述渲染得到用户界面

注意:

①@State装饰器标记的变量必须初始化,不能为空值

②@State支持object、class、string、number、boolean、enum类型以及这些类型的数组

③嵌套类型以及数组中的对象属性无法触发视图更新

例子:

class Person{name:stringage:numberfriend:Personconstructor(name:string,age:number,friend?:Person) {this.name=namethis.age=agethis.friend=friend}}@Entry
@Component
struct Index {@State  message: string = 'Hello World'
@State P:Person=new Person('张三',18,new Person('zz',10))build() {Row() {Column() {// 正常发生变化Text(`${this.P.name}:${this.P.age}`).fontSize(80).fontWeight(FontWeight.Bold).fontColor("red").onClick(()=>{this.P.name="李四"this.P.age++})// 嵌套的对象点击视图不发生变化Text(`${this.P.friend.name}:${this.P.friend.age}`).fontSize(80).fontWeight(FontWeight.Bold).fontColor("red").onClick(()=>{this.P.friend.name="ss"this.P.friend.age++})}.width('100%')}.height('100%')}
}

效果:

2.@State和@Prop单项数据同步(父向子传值)

①父组件


//2.引入子组件
import { AnLi }from "./AnLi"
@Entry
@Component
struct Index {
//   1.父组件声明变量
@State a:number=0build() {Stack(){Column(){// 3.父向子传值AnLi({a:this.a})Button("点击").onClick(()=>{this.a++})}.height("30%").width("100%").backgroundColor("green")}.height("50%").width("100%").backgroundColor("red").alignContent(Alignment.Center)}}

②子组件

@Component
export struct AnLi {//4.@prop接收父组件传过来的变量
@Prop a:numberbuild(){Column(){Text(  `${this.a}`)}}}

2.@State和@Link数据双向同步

①父组件


//2.引入子组件
import { AnLi }from "./AnLi"
@Entry
@Component
struct Index {
//   1.父组件声明变量
@State a:number=0build() {Stack(){Column(){Text( `${this.a}`)// 3.父向子传值AnLi({a:this.a})Button("点击").onClick(()=>{this.a++})}.height("30%").width("100%").backgroundColor("green")}.height("50%").width("100%").backgroundColor("red").alignContent(Alignment.Center)}}

②子组件

@Component
export struct AnLi {//4.@Link接收父组件传过来的变量
@Link a:numberbuild(){Column(){Text(  `${this.a}`)}}}

效果如下:

3.@Provide和@Consume与后代组件双向同步例子如下:

//入口组件,根组件
import { AnLi }from "./AnLi"
@Entry
@Component
struct Index {@Provide a:number=1build() {Stack(){Column(){AnLi()}.height("30%").width("100%").backgroundColor("green")}.height("50%").width("100%").backgroundColor("red").alignContent(Alignment.Center)}}//父组件
import { Consum }from "./Consum"
@Component
export struct AnLi {build(){Column(){Consum()}
}}//子组件
@Component
export struct Consum {@Consume a:numberbuild(){Column(){Text(  `${this.a}`)Text(  `${this.a}`)Button("加以").onClick(()=>{this.a++})}}}

效果如下:

4.@objectLink和@observed装饰器用于在涉及嵌套对象或数组元素为对象的场景中进行双向数据同步

  • 被@Observed装饰的类,可以被观察到属性的变化;
  • 子组件中@ObjectLink装饰器装饰的状态变量用于接收@Observed装饰的类的实例,和父组件中对应的状态变量建立双向数据绑定。这个实例可以是数组中的被@Observed装饰的项,或者是class object中的属性,这个属性同样也需要被@Observed装饰。
  • 单独使用@Observed是没有任何作用的,需要搭配@ObjectLink或者@Prop使用。
限制条件

  • 使用@Observed装饰class会改变class原始的原型链,@Observed和其他类装饰器装饰同一个class可能会带来问题。
  • @ObjectLink装饰器不能在@Entry装饰的自定义组件中使用。
@Observed
class ClassA {public c: number;constructor(c: number) {this.c = c;}
}@Observed
class ClassB {public a: ClassA;constructor(a: ClassA) {this.a = a;}
}@Component
struct ComB{@ObjectLink a:ClassA;build(){Button(`ViewA  this.a.c=${this.a.c} +1`).onClick(() => {this.a.c += 1;})}
}@Entry
@Component
struct Index {@State b: ClassB = new ClassB(new ClassA(0));build() {Stack(){Column(){ComB({a:this.b.a})}.height("30%").width("100%").backgroundColor("green")}.height("50%").width("100%").backgroundColor("red").alignContent(Alignment.Center)}}

效果如下:

这篇关于arkts状态管理使用(@State、@Prop、@Link、@Provide、@Consume、@objectLink和@observed)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/559103

相关文章

Flutter监听当前页面可见与隐藏状态的代码详解

《Flutter监听当前页面可见与隐藏状态的代码详解》文章介绍了如何在Flutter中使用路由观察者来监听应用进入前台或后台状态以及页面的显示和隐藏,并通过代码示例讲解的非常详细,需要的朋友可以参考下... flutter 可以监听 app 进入前台还是后台状态,也可以监听当http://www.cppcn

Python使用PIL库将PNG图片转换为ICO图标的示例代码

《Python使用PIL库将PNG图片转换为ICO图标的示例代码》在软件开发和网站设计中,ICO图标是一种常用的图像格式,特别适用于应用程序图标、网页收藏夹图标等场景,本文将介绍如何使用Python的... 目录引言准备工作代码解析实践操作结果展示结语引言在软件开发和网站设计中,ICO图标是一种常用的图像

使用Java发送邮件到QQ邮箱的完整指南

《使用Java发送邮件到QQ邮箱的完整指南》在现代软件开发中,邮件发送功能是一个常见的需求,无论是用户注册验证、密码重置,还是系统通知,邮件都是一种重要的通信方式,本文将详细介绍如何使用Java编写程... 目录引言1. 准备工作1.1 获取QQ邮箱的SMTP授权码1.2 添加JavaMail依赖2. 实现

MyBatis与其使用方法示例详解

《MyBatis与其使用方法示例详解》MyBatis是一个支持自定义SQL的持久层框架,通过XML文件实现SQL配置和数据映射,简化了JDBC代码的编写,本文给大家介绍MyBatis与其使用方法讲解,... 目录ORM缺优分析MyBATisMyBatis的工作流程MyBatis的基本使用环境准备MyBati

使用Python开发一个图像标注与OCR识别工具

《使用Python开发一个图像标注与OCR识别工具》:本文主要介绍一个使用Python开发的工具,允许用户在图像上进行矩形标注,使用OCR对标注区域进行文本识别,并将结果保存为Excel文件,感兴... 目录项目简介1. 图像加载与显示2. 矩形标注3. OCR识别4. 标注的保存与加载5. 裁剪与重置图像

使用Python实现表格字段智能去重

《使用Python实现表格字段智能去重》在数据分析和处理过程中,数据清洗是一个至关重要的步骤,其中字段去重是一个常见且关键的任务,下面我们看看如何使用Python进行表格字段智能去重吧... 目录一、引言二、数据重复问题的常见场景与影响三、python在数据清洗中的优势四、基于Python的表格字段智能去重

使用Apache POI在Java中实现Excel单元格的合并

《使用ApachePOI在Java中实现Excel单元格的合并》在日常工作中,Excel是一个不可或缺的工具,尤其是在处理大量数据时,本文将介绍如何使用ApachePOI库在Java中实现Excel... 目录工具类介绍工具类代码调用示例依赖配置总结在日常工作中,Excel 是一个不可或缺的工http://

Java之并行流(Parallel Stream)使用详解

《Java之并行流(ParallelStream)使用详解》Java并行流(ParallelStream)通过多线程并行处理集合数据,利用Fork/Join框架加速计算,适用于大规模数据集和计算密集... 目录Java并行流(Parallel Stream)1. 核心概念与原理2. 创建并行流的方式3. 适

如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件

《如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件》本文介绍了如何使用Docker部署FTP服务器和Nginx,并通过HTTP访问FTP中的文件,通过将FTP数据目录挂载到N... 目录docker部署FTP和Nginx并通过HTTP访问FTP里的文件1. 部署 FTP 服务器 (

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、