HarmonyOS --@Prop和@Link同步信息装饰器

当应用中父子组件需要数据同步时,可以使用@Prop和@Link装饰器
一个组件被引用时,引用其他组件的组件就是父组件、被引用的组件就是子组件。
由于@State装饰器无法执行父子之间的数据通信

  1. @Prop:单向同步、父组件中修改数据,会同步到子组件,但是子组件修改数据,父组件中不会同步,底层实现的是传递的父组件中的变量的拷贝。
  2. @Link:双向同步、修改父子组件中的数据,修改会同步到父子组件中,底层实现的是传递的父子组件中的变量的引用。

Prop单向传递

语法: 将一个显示任务数量和完成情况的卡片组件进行封装

@Component  
struct TaskStatic {  @Prop finishTask: number  // Prop变量不需要初始化@Prop totalTask: number  build() {  // ===任务数量显示卡片st===//  Row() {  Text('任务进度:') // 任务进度文字  .whiteFont()  .fontSize(30)  .fontWeight(FontWeight.Bold)  Stack() { // 叠加容器,容器内组件依次入栈,后一个组件覆盖前一个组件  // ===进度条st===//            Progress({ value: this.finishTask, total: this.totalTask, type: ProgressType.Ring })  .width(100)  // ===进度条end===//  Row() { // 两个文本,一个显示完成任务数量,一个显示总的任务数量  Text(this.finishTask.toString()) // 完成任务  .fontSize(24)  .fontColor('#76D')  Text(`/` + this.totalTask.toString()) // 所有任务  .fontSize(24)  .whiteFont()  }         }  }  .card()  .justifyContent(FlexAlign.SpaceEvenly)  // ===任务数量显示卡片end===//  }  
}

入口代码:

@Entry  
@Component  
struct PropPage {  // 总的任务量  @State totalTask: number = 0  // 完成的任务  @State finishTask: number = 0  build() {  Column() {  // 标题栏st//  Header({ title: '任务统计案例' })  // 任务展示卡片组件  prop单向同步显示//  TaskStatic({ finishTask: this.finishTask, totalTask: this.totalTask })  // 任务列表组件//  
TaskList({finishTask:$finishTask,totalTask:$totalTask})  }      .width('100%') // Column宽度  .height('100%') // Column高度  .backgroundColor('#F1F2F3')  }  
}

Link变量初始化

语法:

@Component  
struct TaskList {  @Link finishTask: number  // Link变量也不需要初始化@Link totalTask: number  //任务数组  @State tasks: Task[] = []  handleTaskChange() {  this.totalTask = this.tasks.length // 所有的任务  // 遍历数组,过滤出已经完成的任务数量      this.finishTask = this.tasks.filter(item => item.finished).length  }  build() { // 子元素中必须只有一个根元素  Column() {  // ==新增任务按钮st==//  Button('新增任务')  .onClick(() => {  // 1. 新增任务进入数组  this.tasks.push(new Task())  // 2. 改变任务总数  this.handleTaskChange()  })  .width(100)  .height(40)  .type(ButtonType.Normal)  .borderRadius(15)  .margin(10)  // 新增任按钮end//  // 渲染列表st//         List({ space: 10 }) {  ForEach(this.tasks, (item: Task, index) => {  ListItem() {  Row() {  Text(`新增任务${index}`)  .fontSize(24)  .whiteFont()  Checkbox({ name: 'checkbox' + index.toString() })  .select(item.finished)  .selectedColor(0xed6f21)  .onChange((value: boolean) => {  item.finished = value  this.handleTaskChange()  })  }  .card()  .justifyContent(FlexAlign.SpaceBetween)  .margin(6)  }  .swipeAction({ end: this.deleteButton(index) }) // 列表的右滑功能函数  })  }         .width('100%')  .layoutWeight(1) // 将剩下的空间全部给list元素  .alignListItem(ListItemAlign.Center) // 列表元素居中  // =渲染列表end=//      }  }  @Builder deleteButton(index: number) { // 删除按钮构建函数  Button() {  Image($r('app.media.delete'))  .width(40)  .padding(5)  }      .width(60)  .type(ButtonType.Circle)  .backgroundColor(Color.Brown)  .onClick(() => {  this.tasks.splice(index, 1) // 删除1个  this.handleTaskChange() // 一旦更改任务,就需要重新渲染  })  }  
}
TaskList({finishTask:$finishTask,totalTask:$totalTask})}


传值的时候需要传变量的引用:$+变量名

总结

父组件影响子组件用Prop,父子组件相互影响需要用Link,互不影响使用State

其次,允许装饰的变量类型也不一样,Prop只支持string、number、boolean、enum类型,父组件对象类型,子组件是对象属性。不可以是数组、any类型。

而Link,父子类型一致,string、number、boolean、enum、object、class,以及他们的数组。数组中元素增删、替换都会引起刷新。嵌套类型以及数组中的对象属性无法触发视图更新。

初始化方式上看,Prop不允许子组件初始化,Link由父组件传递,禁止子组件初始化。

也提供了另一种传递方式,@Provide 和@Consume,不需要初始化和传值。

import router from '@ohos.router'  
import { Header } from '../components/herder'  
// 创建Task类  
class Task {  static id: number = 1  name: string = `任务${Task.id++}`  finished: boolean = false  
}  // 创建单独的卡片样式  
@Styles function card() {  .width('95%')  // .height(20)  .padding(20)  .backgroundColor(Color.Brown)  .borderRadius(15)  .shadow({ radius: 6, color: '#1F000000', offsetX: 2, offsetY: 4 })  
}  // 任务完成样式  
@Extend(Text) function finishedCard() {  .decoration({ type: TextDecorationType.LineThrough })  .fontColor('#B1B2B1')  
}  // 任务白色字体  
@Extend(Text) function whiteFont() {  .fontColor(Color.White)  
}  @Entry  
@Component  
struct PropPage {  // 总的任务量  @Provide totalTask: number = 0  // 完成的任务  @Provide finishTask: number = 0  build() {  Column() {  // =======================标题栏st======================//  Header({ title: '任务统计案例' })  // =======================任务展示卡片组件======================//  TaskStatic()  // =======================任务列表组件======================//  TaskList()  }      .width('100%') // Column宽度  .height('100%') // Column高度  .backgroundColor('#F1F2F3')  }  
}  @Component  
struct TaskStatic {  @Consume finishTask: number  @Consume totalTask: number  build() {  // =======================任务数量显示卡片st======================//  Row() {  Text('任务进度:') // 任务进度文字  .whiteFont()  .fontSize(30)  .fontWeight(FontWeight.Bold)  Stack() { // 叠加容器,容器内组件依次入栈,后一个组件覆盖前一个组件  // =======================进度条st======================//            Progress({ value: this.finishTask, total: this.totalTask, type: ProgressType.Ring })  .width(100)  // =======================进度条end======================//  Row() { // 两个文本,一个显示完成任务数量,一个显示总的任务数量  Text(this.finishTask.toString()) // 完成任务  .fontSize(24)  .fontColor('#76D')  Text(`/` + this.totalTask.toString()) // 所有任务  .fontSize(24)  .whiteFont()  }         }  }  .card()  .justifyContent(FlexAlign.SpaceEvenly)  // =======================任务数量显示卡片end======================//  }  
}  @Component  
struct TaskList {  @Consume finishTask: number  @Consume totalTask: number  //任务数组  @State tasks: Task[] = []  handleTaskChange() {  this.totalTask = this.tasks.length // 所有的任务  // 遍历数组,过滤出已经完成的任务数量      this.finishTask = this.tasks.filter(item => item.finished).length  }  build() { // 子元素中必须只有一个根元素  Column() {  // =======================新增任务按钮st======================//  Button('新增任务')  .onClick(() => {  // 1. 新增任务进入数组  this.tasks.push(new Task())  // 2. 改变任务总数  this.handleTaskChange()  })  .width(100)  .height(40)  .type(ButtonType.Normal)  .borderRadius(15)  .margin(10)  // =======================新增任按钮end======================//  // =======================渲染列表st======================//         List({ space: 10 }) {  ForEach(this.tasks, (item: Task, index) => {  ListItem() {  Row() {  Text(`新增任务${index}`)  .fontSize(24)  .whiteFont()  Checkbox({ name: 'checkbox' + index.toString() })  .select(item.finished)  .selectedColor(0xed6f21)  .onChange((value: boolean) => {  item.finished = value  this.handleTaskChange()  })  }  .card()  .justifyContent(FlexAlign.SpaceBetween)  .margin(6)  }  .swipeAction({ end: this.deleteButton(index) }) // 列表的右滑功能函数  })  }         .width('100%')  .layoutWeight(1) // 将剩下的空间全部给list元素  .alignListItem(ListItemAlign.Center) // 列表元素居中  // =======================渲染列表end======================//      }  }  @Builder deleteButton(index: number) { // 删除按钮构建函数  Button() {  Image($r('app.media.delete'))  .width(40)  .padding(5)  }      .width(60)  .type(ButtonType.Circle)  .backgroundColor(Color.Brown)  .onClick(() => {  this.tasks.splice(index, 1) // 删除1个  this.handleTaskChange() // 一旦更改任务,就需要重新渲染  })  }  
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/653413.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

最近公共祖先(LCA)主要算法:

1)向上标记法: 从x向上走到根节点,并标记所有经过的节点。 从y向上走到根节点,当第一次遇到已标记的节点时,就找到了LCA(x,y). 2)树上倍增法: 树上倍增法是一个很重要…

心理学笔记——我们如何思考-思想、语言和手语

我们如何思考-思想、语言和手语 研究语言的理论:计算理论、认知神经学、进化论 当我们讨论语言时,指的是英语、中文、日语这样的语言系统 所有语言都共享一些深层且复杂的共性,最直观的就是每一种语言都能够有效地表达抽象概念——思想、物…

05 Redis之Benchmark+简单动态字符串SDS+集合的底层实现

3.8 Benchmark Redis安装完毕后会自动安装一个redis-benchmark测试工具,其是一个压力测试工具,用于测试 Redis 的性能。 src目录下可找到该工具 通过 redis-benchmark –help 命令可以查看到其用法 3.8.1 测试1 3.9 简单动态字符串SDS 无论是 Redis …

redis原理(五)Lua语言

一、介绍: 1、背景: 在 Redis 的 2.6 以上版本中,除了可以使用命令外,还可以使用 Lua 语言操作 Redis。 Redis 命令的计算能力并不算很强大,而使用 Lua 语言则在很大程度上弥补了 Redis 的这个不足。 2、特点&#…

网络通信实现

【 一 】网络通信实现 【 1 】实现网络通信的四要素 本机的ip地址 子网掩码 网关的IP地址 DNS的IP地址( 域名系统) DNS服务器是指提供域名解析服务的服务器。它负责将域名转换为相应的IP地址,以便计算机可以通过IP地址与其他设备进行通信。 通过使用DNS服务器…

【C语言】linux内核ipoib模块 - ipoib_netdev_ops_pf结构

一、ipoib_netdev_ops_pf结构 static const struct net_device_ops ipoib_netdev_ops_pf {.ndo_init ipoib_ndo_init,.ndo_uninit ipoib_ndo_uninit,.ndo_open ipoib_open,.ndo_stop ipoib_stop,.ndo_change_mtu ipoib_change_mtu,.ndo_…

java servlet勤工助学家教管系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 java servlet 勤工助学家教管系统是一套完善的java web信息管理系统 serlvetdaobean mvc 模式开发 ,对理解JSP java编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myecli…

绝地求生:【PC】开发者日志:竞技比赛地图轮换

各位玩家大家好,欢迎收看闲游盒本期开发者日志。 今天闲游盒想和大家分享一下2024年竞技比赛地图轮换的几项主要改动。 从第28赛季第1轮更新(2月)开始,竞技比赛的地图阵容中将包含所有8x8尺寸的地图,在电竞赛事中出场…

linux ping 某台服务的端口

在 Linux 中&#xff0c;可以使用 telnet 命令来测试远程主机的端口是否可达。以下是使用 telnet 命令来 ping 端口的示例&#xff1a; telnet <远程主机IP> <端口号> 例如&#xff0c;如果要测试远程主机 192.168.1.100 的端口 80 是否可达&#xff0c;可以使用…

SpringBoot-yml文件的配置与读取

配置 值前边必须要有空格&#xff0c;作为分隔符 使用空格作为缩进表示层级关系&#xff0c;相同的层级左侧对齐 获取 使用Value(”${键名}”) 使用ConfigurationProperties(prefix "前缀") 1.前缀要与yml配置文件中的前缀一致 2.实体类的字段名与配置文件中的键名一…

Spring中的bean配置

配置说明 类别描述名称bean类型标签所属beans标签功能定义Spring核心容器管理的对象格式 属性列表id:bean的id&#xff0c;使用容器可以通过id值获取对应的bean&#xff0c;在一个容器中id是唯一的class:bean的类型&#xff0c;即配置的bean的全路径类名范例 1、Bean别名配置 …

【微服务】springboot集成ELK使用详解

目录 一、前言 二、为什么需要ELK 三、ELK介绍 3.1 什么是elk 3.2 elk工作原理 四、ELK环境搭建 4.1 搭建es环境 4.1.1 获取es镜像 4.1.2 启动es容器 2.1.3 配置es参数 2.1.4 重启es容器并访问 4.2 搭建kibana 4.2.1 拉取kibana镜像 4.2.2 启动kibana容器 4.2.3 …

GitLab16.8配置webhooks、Jenkins2.4配置GitLab插件实现持续集成、配置宝塔面板实现持续部署

看本篇文章的前提是已经部署完GItlab和Jenkins服务器&#xff0c;已经可以手动构建成功&#xff0c;并且经过了很多次实践&#xff0c;对这两款软件基本熟悉。 建议大家按以下顺序看 前端自动化&#xff08;其一&#xff09;部署gitlab https://blog.csdn.net/weixin_45062076…

【Redis】Redis集群方案应该怎么做 都有哪些方案

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a;Redis ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言 正文 &#xff08;1&#xff09;twemproxy &#xff08;2&#xff09;codis &#xff08;3&#xff09;redis cluster3.0自带的集群 …

爬虫基础-前端基础

Html是骨骼、css是皮肤、js是肌肉&#xff0c;三者之间的关系可以简单理解为m(html)-v(css)-c(js) 浏览器的加载过程 构建dom树 子资源加载-加载外部的css、图片、js等外部资源 样式渲染-css执行 DOM树 ajax、json、xml AJAX 是一种在无需重新加载整个网页的情况下&#xf…

iOS_Xcode_LLDB调试常用命令

文章目录 结构常用命令&#xff1a;1、流程控制&#xff1a;2、常用命令3、进程信息&#xff1a;4、寄存器&#xff1a;register5、镜像&#xff1a;image6、内存&#xff1a;memory7、符号断点&#xff1a;breakpoint8、内存断点&#xff1a;watchpoint9、Tips&#xff1a; 结…

MySQL 学习记录

基本常识 row-size-limitsblob&#xff1a; BLOB and TEXT columns cannot have DEFAULT values.Instances of BLOB or TEXT columns in the result of a query that is processed using a temporary table causes the server to use a table on disk rather than in memory b…

Linux命令-apt-get命令(Debian Linux发行版中的APT软件包管理工具)

补充说明 apt-get命令 是Debian Linux发行版中的APT软件包管理工具。所有基于Debian的发行都使用这个 包管理系统。deb包可以把一个应用的文件包在一起&#xff0c;大体就如同Windows上的安装文件。 语法 apt-get [OPTION] PACKAGE选项 apt-get install 安装新包 apt-get r…

【vue】图片加载骨架

一、前言 在网速较低或者网站的服务器宽带只有几MB的情况下&#xff0c;网页中的图片加载时&#xff0c;要么空白&#xff0c;要么像打印机一样一行一行地“扫描”出来&#xff0c;为了提升用户体验&#xff0c;可以给图片标签外加一层骨架。 无骨架 有骨架 二、详细设计 每张…

MySQL之索引分类,语法以及SQL性能分析(慢日志,profile,explain)

索引分类 分类含义特定关键字主键索引针对于表中主键创建的索引默认自动创建&#xff0c;只能有一个PRIMARY唯一索引避免同一个表中某数据列中的值重复可以有多个UNIQUE常规索引快速定位特定数据可以有多个全文索引全文索引查找的文本中的关键字&#xff0c;而不是比较索引中的…