HarmonyOS学习 实验九:@State和@Prop装饰器的使用方法

news2025/5/25 19:57:44

HarmonyOS应用开发:父子组件状态管理实验报告

引言

在HarmonyOS应用开发领域,组件之间的状态管理是一个至关重要的概念。通过有效的状态管理,我们可以确保应用的数据流动清晰、可预测,从而提升应用的稳定性和可维护性。本次实验旨在探索HarmonyOS中父子组件之间的状态管理机制,特别是通过@State@Prop装饰器实现状态传递的方法。

实验目的

本次实验的主要目的是在HarmonyOS应用中实现父子组件的状态管理,具体目标包括:

  • 掌握@State装饰器的使用方法,用于在组件内部定义和管理状态。
  • 理解@Prop装饰器的作用,实现父组件向子组件的状态传递。
  • 验证单向数据流的状态管理机制,确保子组件不能直接修改父组件的状态。

实验环境与技术栈

  • 开发软件:DevEco Studio(HarmonyOS官方推荐的集成开发环境)
  • 操作系统:HarmonyOS(实验在HarmonyOS设备上运行)
  • API版本:API9(确保兼容性和最新特性支持)
  • 编程语言与框架:ets(Extensible TypeScript),ArkUI框架(HarmonyOS的声明式UI开发框架)

实验步骤与代码实现

1. 创建父组件(ParentComponent.ets)

父组件是状态管理的核心,它负责定义和更新状态,并将状态传递给子组件。以下是父组件的关键代码实现:

// ParentComponent.ets
import {ChildComponent} from './ChildComponent';
@Entry
@Component
struct ParentComponent {
  // 父组件的状态变量,用于控制子组件的状态
  @State count: number = 0;

  build() {
    Column() {
      Text(`父组件计数: ${this.count}`)
        .fontSize(20)
        .margin({ top: 20 })

      // 增加计数按钮
      Button("增加计数")
        .margin({ top: 10 })
        .onClick(() => {
        this.count++;
      })

      // 减少计数按钮
      Button("减少计数")
        .margin({ top: 10 })
        .onClick(() => {
        this.count = Math.max(0, this.count - 1);
      })

      // 创建子组件,并将父组件的状态传递给子组件
      ChildComponent({ count: this.count })
    }
    .width("100%")
    .height("100%")
  }
}

2. 创建子组件(ChildComponent.ets)

子组件负责接收并展示父组件传递的状态,但不能直接修改父组件的状态。以下是子组件的关键代码实现:

// ChildComponent.ets
export {ChildComponent}
@Entry
@Component
struct ChildComponent {
  // 使用@Prop装饰器接收父组件传递的状态
  @Prop count: number;

  build() {
    Column() {
      Text(`子组件接收到的计数: ${this.count}`)
        .fontSize(18)
        .margin({ top: 20 })

      // 子组件内部按钮,尝试修改父组件的状态(但不会生效,因为@Prop是单向绑定)
      Button("尝试修改父组件计数(无效)")
        .margin({ top: 10 })
        .onClick(() => {
        this.count = 100; // 这里修改不会影响父组件
      })
    }
    .width("100%")
    .height("100%")
  }
}

3.效果

在这里插入图片描述

在这里插入图片描述

遇到的问题及解决方案

在实验过程中,我们遇到了一个问题:在子组件中尝试修改父组件的状态时,发现修改无效。经过查阅文档和资料,我们理解到@Prop装饰器是单向绑定的,子组件不能直接修改父组件的状态。如果需要修改父组件的状态,应该通过事件回调的方式通知父组件进行修改。

实验结论与展望

通过本次实验,我们成功实现了HarmonyOS应用中父子组件的状态管理,验证了@State@Prop装饰器的使用方法,并深刻理解了单向数据流的状态管理机制。这些知识为后续更复杂的应用开发奠定了坚实的基础。

展望未来,我们将进一步探索HarmonyOS中的其他状态管理方案,如使用@Link装饰器实现双向绑定,以及利用状态管理库(如Redux)进行更复杂的状态管理。同时,我们也将关注HarmonyOS生态的不断发展和完善,期待更多高效、便捷的状态管理工具和方法的出现。


通过本次实验,我们不仅掌握了HarmonyOS中父子组件状态管理的基本方法,还深刻理解了单向数据流的重要性。希望这篇博客能够为HarmonyOS开发者提供一些有益的参考和借鉴。

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

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

相关文章

【Ai】MCP实战:手写 client 和 server [Python版本]

什么是mcp MCP 是一个开放协议,它为应用程序向 LLM 提供上下文的方式进行了标准化。你可以将 MCP 想象成 AI 应用程序的 USB-C 接口。就像 USB-C 为设备连接各种外设和配件提供了标准化的方式一样,MCP 为 AI 模型连接各种数据源和工具提供了标准化的接口…

Java与C在典型场景下的性能对比深度剖析

🎁个人主页:User_芊芊君子 🎉欢迎大家点赞👍评论📝收藏⭐文章 🔍系列专栏:AI 【前言】 在计算机编程领域,Java和C语言都是举足轻重的编程语言。Java以其跨平台性、自动内存管理和丰富…

多智能体 AI 游戏框架(开源程序):竞争、发展、适应

一、软件介绍 文末提供程序和源码下载 SamoAI 在人类和 AI 之间创建了一个无缝的多代理叙事层,实现了跨多个平台的自然协作。通过一致的身份保留和情境记忆,它允许通过一系列行动随着时间的推移而演变的交互,就像人际关系一样。 二、核心概念…

java实现二叉树的前序、中序、后序遍历(递归和非递归方式)以及层级遍历

java实现二叉树的前序、中序、后序遍历以及层级遍历 一、二叉树节点定义二、递归方式1.前序遍历2.中序遍历3.后序遍历 三、非递归方式1.前序遍历2.中序遍历3.后序遍历4.层级遍历5.分层打印 四、测试用例 一、二叉树节点定义 class TreeNode {int val;TreeNode left;TreeNode r…

Solr admin 更新文档

<add><doc><field name"id">1904451090351546368</field><field name"companyName" update"set">测试科技有限公司</field></doc> </add>

【Netty篇】EventLoopGroup 与 EventLoop 详解

目录 开场白&#xff1a;话说 Netty 江湖第一段&#xff1a;EventLoopGroup——“包工头”的角色第二段&#xff1a;EventLoop——“身怀绝技的工人”第三段&#xff1a;EventLoop 如何处理 I/O 事件、普通任务和定时任务第四段&#xff1a;Handler 执行中如何换人&#xff1f;…

操作系统之shell实现(上)

&#x1f31f; 各位看官好&#xff0c;我是maomi_9526&#xff01; &#x1f30d; 种一棵树最好是十年前&#xff0c;其次是现在&#xff01; &#x1f680; 今天来学习C语言的相关知识。 &#x1f44d; 如果觉得这篇文章有帮助&#xff0c;欢迎您一键三连&#xff0c;分享给更…

数据结构与算法——链表OJ题详解(2)

文章目录 一、前言二、OJ续享2.1相交链表2.2环形链表12.2环形链表2 三、总结 一、前言 哦了兄弟们&#xff0c;咱们上次在详解链表OJ题的时候&#xff0c;有一部分OJ题呢up并没有整理完&#xff0c;这一个星期呢&#xff0c;up也是在不断的学习并且沉淀着&#xff0c;也是终于…

Linux 基础知识详解

Linux 基础知识详解 一、快照与克隆 1. &#x1f4f8;快照&#xff08;Snapshot&#xff09; 快照是虚拟机当前运行状态的一次“瞬间拷贝”&#xff0c;包括内存、磁盘、配置等信息。这使得管理员能够快速恢复到某个特定的时间点。 用途&#xff1a; 安全实验前保存状态&am…

centOs7配置有限网络

最简单快速的是使用nmtui命令&#xff0c;采用图形页面修改。 点击编辑连接并回车&#xff1a; 选中编辑然后回车&#xff1a; 千万记住DNS服务器就是子网掩码&#xff0c;不是常说的DNS域名。把地址&#xff0c;网关&#xff0c;子网掩码配置好。只要ip不冲突&#xff0c;网…

C语言 —— 指尖跃迁 刻印永恒 - 文件操作

目录 1. 什么是文件 1.1 程序文件 1.2 数据文件 1.3 文件名 2. 二进制文件和文本文件 3. 文件的打开与关闭 3.1 流和标准流 3.2 文件指针 3.3 文件的打开与关闭 fopen fclose 4. 文件的顺序读写 4.1 fgetc和fputc fgetc fputc 4.2 fgets和fputs fgets fputs…

网络安全与信息安全的区别​及共通

在数字化时代&#xff0c;网络安全与信息安全已成为保障个人、企业乃至国家正常运转的重要防线。尽管二者紧密相关且常被混为一谈&#xff0c;但实则存在显著差异。当然&#xff0c;它们也有一些相同点&#xff0c;比如都以保障数字环境下的安全为核心目标&#xff0c;均需要通…

【愚公系列】《Python网络爬虫从入门到精通》052-Scrapy 编写 Item Pipeline

&#x1f31f;【技术大咖愚公搬代码&#xff1a;全栈专家的成长之路&#xff0c;你关注的宝藏博主在这里&#xff01;】&#x1f31f; &#x1f4e3;开发者圈持续输出高质量干货的"愚公精神"践行者——全网百万开发者都在追更的顶级技术博主&#xff01; &#x1f…

【AI News | 20250416】每日AI进展

AI Repos 1、Tutorial-Codebase-Knowledge 自动分析 GitHub 仓库并生成适合初学者的通俗易懂教程&#xff0c;清晰解释代码如何运行&#xff0c;还能生成可视化内容来展示核心功能。爬取 GitHub 仓库并从代码中构建知识库&#xff1b;分析整个代码库以识别核心抽象概念及其交互…

GIS开发笔记(6)结合osg及osgEarth实现半球形区域绘制

一、实现效果 输入中心点坐标及半径&#xff0c;绘制半球形区域&#xff0c;地下部分不显示。 二、实现原理 根据中心点及半径绘制半球形区域&#xff0c;将其挂接到地球节点。 三、参考代码 void GlobeWidget::drawSphericalRegion(osg::Vec3d point,double radius) {// 使…

element-ui自定义主题

此处的element-ui为基于vue2.x的 由于https://element.eleme.cn/#/zh-CN/theme/preview&#xff08;element的主题&#xff09;报错503&#xff0c; 所以使用https://element.eleme.cn/#/zh-CN/component/custom-theme 自定义主题文档中&#xff0c;在项目中改变scss变量的方…

windows下使用nginx + waitress 部署django

架构介绍 linux一般采用nginx uwsgi部署django&#xff0c;在Windows下&#xff0c;可以取代uwsgi的选项包括Waitressa、Daphnea、Hypercoma和Gunicorna(通过WSLa 运行)。windows服务器一般采用nginx waitress 部署django&#xff0c;,他们的关系如下 django是WEB应用…

MySQL-多版本并发控制MVCC

文章目录 一、多版本并发控制MVCC二、undo log&#xff08;回滚日志&#xff09;二、已提交读三、可重复读总结 一、多版本并发控制MVCC MVCC是多版本并发控制&#xff08;Multi-Version Concurrency Control&#xff09;&#xff0c;是MySQL中基于乐观锁理论实现隔离级别的方…

目标检测与分割:深度学习在视觉中的应用

&#x1f50d; PART 1&#xff1a;目标检测&#xff08;Object Detection&#xff09; 1️⃣ 什么是目标检测&#xff1f; 目标检测是计算机视觉中的一个任务&#xff0c;目标是让模型“在图像中找到物体”&#xff0c;并且判断&#xff1a; 它是什么类别&#xff08;classif…

杰弗里·辛顿:深度学习教父

名人说&#xff1a;路漫漫其修远兮&#xff0c;吾将上下而求索。—— 屈原《离骚》 创作者&#xff1a;Code_流苏(CSDN)&#xff08;一个喜欢古诗词和编程的Coder&#x1f60a;&#xff09; 杰弗里辛顿&#xff1a;当坚持遇见突破&#xff0c;AI迎来新纪元 一、人物简介 杰弗…