Harmony状态管理@Event

Harmony状态管理@Event

背景

在上一节中,我们针对父子组件,讲了关于传递数据的知识。我们了解到

  1. @Local 是管理自己内部的数据的,
  2. @Param 是负责接收父组件的数据的,而且子自己内部不能直接修改

按照一个组件最基本的功能,既能接收外部传入的数据也要向外部传递数据 。那么 @Event 修饰符就是来解决这个问题的了。

介绍

@Event 是 子组件向父组件传递数据的技术,它只能用在 @ComponentV2 修改的组件上,其中的思想是

  1. 完成修改数据的操作,还是放在父组件内部,通过定义一个函数 func 来实现
  2. 在父组件调用子组件的时候,也顺带把这个函数 func 传递给子组件
  3. 子组件在内部 使用 @Event 来修饰 该函数,并且在需要的使用直接调用即可

父组件

  1. 定义内部数据 num

  2. 定义修改内部数据num的函数 func

  3. 使用子组件时,把numfunc都传递过去

    @Entry
    @ComponentV2
    struct Index {
    @Local num: number = 100
    // 自己定义的函数 负责修改数据, 该函数也要传递给子组件
    func = (unit: number) => {
    this.num -= unit
    }

    build() {
    Column() {
    Button("父组件 修改" + this.num)
    .onClick(() => {
    this.num++
    })
    // 使用子组件,并且传递数据 和 传递函数
    Son({ num: this.num, func: this.func })
    .padding(10)
    }
    .width("100%")

    }
    }

子组件

  1. 使用 @Param 接收父组件传递的 num

  2. 使用@Event 接收父组件传递的函数 func

  3. 定义点击事件的处理函数 onfunc,内部直接调用父组件传递过来的函数

    @ComponentV2
    struct Son {
    @Param num: number = 0
    @Event func: (num: number) => void = () => {
    }
    onfunc = () => {
    this.func(5)
    }

    build() {

    复制代码
     Column() {
       Button(`子组件 ${this.num}`)
    
       Button("子组件修改父组件中的状态")
         .onClick(this.onfunc)
     }
     .border({
       width: 1,
       style: BorderStyle.Dashed
     })

    }
    }

流程

@Once

@Once@Param作用类似,都可以表示接收父组件传递过来的数据,但是也存在区别

  1. @Once 只会接收第一次父组件传递过来的数据,后续父组件的数据修改,不会同步到 @Once修改的变量上

  2. @Once 需要和 @Param 一起搭配使用,因为 @Param 修饰的是父组件传递给子组件的变量,该变量不能直接被修改。所以@Once修饰的变量,也不能在子组件内部直接修改。

    @ComponentV2
    struct Son {
    @Once @Param num: number = 0

    build() {
    Column() {
    Button(子组件 ${this.num})
    .onClick(() => {
    this.num++ // 修改无效
    })
    }
    .border({
    width: 1,
    style: BorderStyle.Dashed
    })
    }
    }

    @Entry
    @ComponentV2
    struct Index {
    @Local num: number = 100

    build() {
    Column() {

    复制代码
       Son({ num: this.num })
         .padding(10)
     }
     .width("100%")

    }
    }

总结

  1. @Param 表示父组件传递给子组件的数据,当父组件修改了,子组件会跟随响应,同时子组件内部不能直接修改 @Param修饰的变量
  2. @Event 表示子组件想要修改父组件数据的一种技术,它用来修改函数,该函数是由父组件定义和传递给子组件的
  3. @Once 必须和 @Param 搭配使用,表示父组件传递过来的数据,只会第一次生效。
相关推荐
木咺吟3 小时前
鸿蒙原生应用实战(一):从零搭建快递追踪App——项目初始化与工程架构详解
华为·harmonyos
坚果派·白晓明6 小时前
【鸿蒙PC】SDL3 移植:AtomCode Skills 4 步速通多媒体库适配
c++·华为·ai编程·harmonyos·atomcode·c/c++三方库
风满城337 小时前
鸿蒙原生应用实战(三):设置与统计页面开发 — 数据驱动的功能模块
harmonyos
xcLeigh7 小时前
鸿蒙平台 KeePass 密码管理器适配实战:从 Windows 到 鸿蒙PC 的 Electron 迁移指南
windows·electron·web·harmonyos·加密算法·keepass
金启攻7 小时前
鸿蒙原生应用开发实战(一):从零搭建“钓点日记“——项目初始化与环境配置全指南
harmonyos
风华圆舞7 小时前
鸿蒙语音识别为什么要区分 startListening 和 stopListening
华为·语音识别·harmonyos
YM52e8 小时前
鸿蒙PC ArkTS 声明合并问题深度解析与最佳实践
学习·华为·harmonyos·鸿蒙·鸿蒙系统
互联网散修8 小时前
鸿蒙实战:网络状态监听与诊断工具
网络·华为·harmonyos·网络状态监听
祭曦念9 小时前
从零开始构建鸿蒙纪念日提醒 App:ArkTS + API 24 实战
华为·harmonyos
浮芷.9 小时前
鸿蒙HarmonyOS 6.1新特性之沉浸式光感效果实现过程中的各类问题解决-鸿蒙PC版(一)
华为·harmonyos·鸿蒙·鸿蒙系统