码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • HarmonyOS鸿蒙学习笔记(6) @Consume和@Provide作用说明和简单案例


    这两个标签在HarmonyOS中很重要,官方文档对其解释是:Provide作为数据的提供方,可以更新其子孙节点的数据,并触发页面渲染。Consume在感知到Provide数据的更新后,会触发当前view的重新渲染。
    下面写个简单的demo代码来理解下,代码如下,注意@Provide修饰的变量,并不需要通过类似Java的set或者构造器的方式赋值给@Consume的变量,只需要保持两者的变量名一样即可。:

    @Entry
    @Component
    struct ProvidePage {
      @Provide count: number = 1
      build() {
        Column() {
          //蓝色数字
          Text(`${this.count}`).fontColor(Color.Blue).fontSize(30)
          //使用ConsumeComponent的时候并没有将ProvidePage.count传给ConsumeComponent
          ConsumeComponent()
        }.height('100%')
        .width('100%')
        .alignItems(HorizontalAlign.Center)
        .justifyContent(FlexAlign.Center)
    
      }
    }
    
    @Component
    struct ConsumeComponent {
      //变量名要跟@Provide一样
      @Consume count: number
      build() {
        Column() {
          //红色数字
          Text(this.count.toString()).fontSize(30)
            .fontColor(Color.Red).margin({ top: 30 })
          //点击+1
          Text("点击+1").fontSize(30).onClick(() => {
            this.count++
          }).margin({ top: 30 })
        }
    
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35

    运行效果如下:
    在这里插入图片描述
    然后点击三次“点击+1”按钮,会自动刷新页面,效果如下:
    在这里插入图片描述
    同理,我们将 @Provide修饰的变量进行count++操作,效果也一样ProvidePage 改造如下,为Text新增点击事件:

    @Entry
    @Component
    struct ProvidePage {
      @Provide count: number = 1
      build() {
        Column() {
          //蓝色数字
          Text(`${this.count}`).fontColor(Color.Blue).fontSize(30)
            .onClick(() => {
            this.count++
          })
          ConsumeComponent()
        }.height('100%')
        .width('100%')
        .alignItems(HorizontalAlign.Center)
        .justifyContent(FlexAlign.Center)
    
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    经过测试发现:
    1、当我们点击上面的蓝色Text的时候执行count++,比如此时count=2;再点击“点击+1”按钮,count就会在2的基础上+1.而变成了3,蓝色Text和红色Text此时都展示3;
    2、同理,我们点击下面的“点击+1”按钮进行count++,假设count=3,那么再点击蓝色Text,此时count就在3的基础上+1.数字变成4,Text和红色Text此时都展示4;

    注意@Provide修饰的变量,并不需要通过类似Java的set或者构造器的方式赋值给@Consume的变量,只需要保持两者的变量名一样即可。
    事实上,HarmonyOs也提供了一个@Link也可以实现上述效果,感兴趣的读者可以阅读博主HarmonyOS鸿蒙学习笔记(12)@Link的作用一文了解一下。
    参考资料:

    Consume和Provide官方资料

  • 相关阅读:
    [车联网安全自学篇] 九. ATTACK安全之Android车机证书攻击(入侵)场景检测【一】
    基础 | 并发编程 - [线程状态 & 中断]
    今日配音热点来袭|想给短视频加配音就赶紧看过来吧
    第4季4:图像sensor的驱动源码解析
    基于web在线餐饮网站的设计与实现——仿Coco线上订奶茶饮料6个页面(HTML+CSS+JavaScript)
    探究Socks5代理和代理IP在技术领域的多重应用
    在 VirtualBox 虚拟机上搭建 openEuler 并安装桌面环境 详细教程
    Java(三)逻辑控制(if....else,循环语句)与方法
    746. 使用最小花费爬楼梯 (Swift版本)
    Ubuntu22.04防火墙ufw用法
  • 原文地址:https://blog.csdn.net/chunqiuwei/article/details/126544341
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号