当前位置: 首页 > news >正文

Harmony状态管理@Event

ArkUI @Event装饰器:实现子组件向父组件通信的规范方式

概述

@Event装饰器是ArkUI框架中用于规范组件间通信的重要工具,特别是在需要子组件向父组件请求更新@Param变量的场景下。它通过回调机制实现数据的双向同步,是组件化开发中不可或缺的一部分。

核心功能

@Event装饰器主要实现以下功能:

  1. 允许子组件通过回调方法向父组件请求数据更新
  2. 配合@Param装饰器实现父子组件间的数据双向同步
  3. 通过@Local同步机制将修改后的值异步同步回子组件的@Param变量

基本用法

@ComponentV2
struct ChildComponent {@Param title: string = '';@Event changeTitle: (newTitle: string) => void = () => {};build() {Column() {Text(this.title)Button('修改标题').onClick(() => {this.changeTitle('新标题'); // 触发父组件回调})}}
}@Entry
@ComponentV2
struct ParentComponent {@Local title: string = '初始标题';build() {Column() {ChildComponent({title: this.title,changeTitle: (newTitle: string) => {this.title = newTitle; // 接收子组件的修改请求}})}}
}

关键特性

  1. 回调方法规范
    • @Event装饰的回调方法参数和返回值由开发者自由定义
    • 当@Event没有初始化时,会自动生成一个空函数作为默认回调
    • 如果本地有默认值,会使用本地默认函数处理
  2. 同步机制
    • 使用@Event修改父组件的值是立即生效的
    • 但从父组件同步回子组件的过程是异步的
    • 在调用@Event方法后,子组件内的值不会立刻变化
  3. 装饰器组合
    • @Event必须与@Param配合使用
    • 通常与@Local一起实现完整的数据流

实际应用示例

// 待办事项子组件
@ComponentV2
struct TaskItem {@Param taskName: string = '';@Param @Once isFinish: boolean = false;@Event deleteTask: () => void = () => {};build() {Row() {Image(this.isFinish ? 'finished.png' : 'unfinished.png')Text(this.taskName)Button('删除').onClick(() => this.deleteTask())}}
}// 父组件
@Entry
@ComponentV2
struct TodoList {@Local tasks: string[] = ['任务1', '任务2', '任务3'];build() {Column() {Repeat(this.tasks).each((item: string) => {TaskItem({taskName: item,deleteTask: () => {this.tasks.splice(this.tasks.indexOf(item), 1)}})})}}
}

注意事项

  1. @Event只能用在@ComponentV2装饰的自定义组件中
  2. 装饰非方法类型的变量时不会有任何作用
  3. 在非@ComponentV2组件中使用会编译报错
  4. 修改父组件值后,子组件更新是异步的,不能立即获取新值

总结

@Event装饰器为ArkUI提供了一种规范的子父组件通信机制,使得数据流更加清晰可控。通过@Event、@Param和@Local的配合使用,开发者可以轻松实现复杂的组件交互逻辑,同时保持代码的可维护性和可读性。

http://www.lqws.cn/news/511291.html

相关文章:

  • ubuntu16编译paho.mqtt.c 及 paho.mqtt.cpp编译问题
  • 屠龙刀策略
  • Web攻防-CSRF跨站请求伪造Referer同源Token校验复用删除置空联动上传或XSS
  • 统计学纯基础(1)
  • C++ 快速回顾(一)
  • 学习记录:DAY33
  • linux操作系统的软件架构分析
  • Redis 分布式锁原理与实战-学习篇
  • 我的字节一面
  • DeepSeek智能总结 | 邓紫棋音乐版权纠纷核心梳理
  • Dify,FastGPT,RagFlow有啥区别,在智能问答方面有啥区别
  • 主机复制文字和文件到 Ubuntu 虚拟机
  • SEO与SEM:了解如何优化网站
  • NVME驱动分析
  • 2025湖北省职业院校技能大赛信息安全管理与评估样题
  • Unity3D仿星露谷物语开发70之背景音乐
  • 深度解析:2D写实数字人交互场景的创新与应用
  • 华为云Flexus+DeepSeek征文 | 基于ModelArts Studio、DeepSeek大模型和Dify搭建智能聊天助手
  • PostgreSQL(二十八)执行计划与单表查询成本估算
  • Git提交失败?commit hook:lint-staged
  • Handle本地部署
  • JVM的内存模型和内存结构
  • 模块化桌面机器人概念设计​​ - ModBot
  • 七天学会SpringCloud分布式微服务——01
  • Vue的学习内容和目标
  • 10-C#的dataGridView1和datatable的使用
  • vue 3 计算器
  • 用 Python 打造立体数据世界:3D 堆叠条形图绘制全解析
  • STM32学习笔记——中断控制
  • 利用大型语言模型增强边缘云 AI 系统安全性