鸿蒙中级课程笔记2—状态管理V2—@Provider装饰器和@Consumer装饰器:跨组件层级双向同步

@Provider和@Consumer用于跨组件层级数据双向同步,可以使得开发者不用拘泥于组件层级。

@Provider和@Consumer属于状态管理V2装饰器,所以只能在@ComponentV2中才能使用,在@Component中使用会编译报错。

@Provider和@Consumer提供了跨组件层级数据双向同步的能力。在阅读本文档前,建议提前阅读:@ComponentV2。常见问题请参考组件内状态变量常见问题。

说明

@Provider和@Consumer装饰器从API version 12开始支持。

从API version 12开始,@Provider和@Consumer装饰器支持在元服务中使用。

从API version 22开始,通过配置BuilderNode的BuildOptions参数enableProvideConsumeCrossing为true,使得@Provider和@Consumer支持跨BuilderNode双向同步。在BuilderNode挂载到自定义组件节点树之后,@Consumer会重新获取最近的@Provider数据,与之建立双向同步关系。具体可见@Consumer在跨BuilderNode场景下和@Provider建立双向同步。

概述

@Provider,即数据提供方,其所有的子组件都可以通过@Consumer绑定相同的key来获取@Provider提供的数据。

@Consumer,即数据消费方,可以通过绑定同样的key获取其最近父节点的@Provider的数据,当查找不到@Provider的数据时,使用本地默认值。图示如下。

@Provider和@Consumer装饰的数据类型需要一致。

开发者在使用@Provider和@Consumer时要注意:

  • @Provider和@Consumer强依赖自定义组件层级,@Consumer会因为所在组件的父组件不同,而被初始化为不同的值。
  • @Provider和@Consumer相当于把组件粘合在一起了,从组件独立角度考虑,应减少使用@Provider和@Consumer。

@Provider和@Consumer vs @Provide和@Consume能力对比

在状态管理V1版本中,提供跨组件层级双向的装饰器为@Provide和@Consume,当前文档介绍的是状态管理V2装饰器@Provider和@Consumer。虽然两者名字和功能类似,但在特性上还存在一些差异。

如果开发者不了解状态管理V1中的@Provide和@Consume,可以直接跳过本节。

能力V2装饰器@Provider和@ConsumerV1装饰器@Provide和@Consume
@Consume(r)必须本地初始化,当找不到@Provider时使用本地默认值。API version 20以前,@Consume禁止本地初始化,当找不到对应@Provide的时候,会抛出异常;从API version 20开始,@Consume支持设置默认值,如果没有设置默认值,且找不到对应@Provide时,会抛出异常。
支持类型支持function。不支持function。
观察能力仅能观察自身赋值变化,如果要观察嵌套场景,配合@Trace一起使用。观察第一层变化,如果要观察嵌套场景,配合@Observed和@ObjectLink一起使用。
alias和属性名alias是唯一匹配的key,缺省时默认属性名为alias。alias和属性名都为key,优先匹配alias,匹配不到可以匹配属性名。
@Provide(r) 从父组件初始化不允许。允许。
@Provide(r)支持重载默认开启,即@Provider可以重名,@Consumer向上查找最近的@Provider。默认关闭,即在组件树上不允许有同名@Provide。如果需要重载,则需要配置allowOverride。

装饰器说明

基本规则

@Provider语法:

@Provider(aliasName?: string) varName : varType = initValue

@Provider属性装饰器说明
装饰器参数aliasName?: string,别名,缺省时默认为属性名。
支持类型自定义组件中成员变量。属性的类型可以为number、string、boolean、class、Array、Date、Map、Set等类型。支持装饰箭头函数。
从父组件初始化禁止
本地初始化必须本地初始化。
观察能力能力等同于@Trace。变化会同步给对应的@Consumer。

@Consumer语法:

@Consumer(aliasName?: string) varName : varType = initValue

@Consumer属性装饰器说明
装饰器参数aliasName?: string,别名,缺省时默认为属性名,向上查找最近的@Provider。
可装饰的变量自定义组件中成员变量。属性的类型可以为number、string、boolean、class、Array、Date、Map、Set等类型。支持装饰箭头函数。
从父组件初始化禁止
本地初始化必须本地初始化。
观察能力能力等同于@Trace。变化会同步给对应的@Provider。

aliasName和属性名

@Provider和@Consumer接受可选参数aliasName,没有配置参数时,使用属性名作为默认的aliasName。

说明

aliasName是用于@Provider和@Consumer进行匹配的唯一指定key。

变量传递

传递规则说明
从父组件初始化@Provider和@Consumer装饰的变量仅允许本地初始化,不允许从外部传入初始化。
初始化子组件@Provider和@Consumer装饰的变量可以初始化子组件中@Param装饰的变量。

使用限制

  1. @Provider和@Consumer为自定义组件的属性装饰器,只能装饰自定义组件内的属性,不能装饰class的属性
  2. @Provider和@Consumer为状态管理V2装饰器,只能在@ComponentV2中使用,不能在@Component中使用。
  3. @Provider和@Consumer只支持本地初始化,不支持外部传入初始化。

使用场景

例子参考鸿蒙中级课程笔记2—状态管理V2—@Provider装饰器和@Consumer装饰器:跨组件层级双向同步

@Provider和@Consumer双向同步

建立双向绑定

  1. 自定义组件Parent和Child初始化:
    • Child中@Consumer() str: string = 'world'向上查找,查找到Parent中声明的@Provider() str: string = 'hello'。
    • @Consumer() str: string = 'world'初始化为其查找到的@Provider的值,即'hello'。
    • 两者建立双向同步关系。
  2. 点击Parent中的按钮,改变@Provider装饰的str,通知其对应的@Consumer,对应UI刷新。同时Parent中UI也刷新。
  3. 点击Child中的按钮,改变@Consumer装饰的str,通知其对应的@Provider,对应UI刷新。同时Child中UI也刷新。

未建立双向绑定

下面的例子中,@Provider和@Consumer由于aliasName值不同,无法建立双向同步关系。

  1. 自定义组件Parent和Child初始化:
    • Child中@Consumer() str: string = 'world'向上查找,未查找到其数据提供方@Provider。
    • @Consumer() str: string = 'world'使用其本地默认值为'world'。
    • 两者未建立双向同步关系。
  2. 点击Parent中的按钮,改变@Provider装饰的str1,仅刷新@Provider关联的Button组件。
  3. 点击Child中的按钮,改变@Consumer装饰的str,仅刷新@Consumer关联的Button组件。

装饰Array类型变量

当装饰的对象是Array时,可以观察到Array整体的赋值,同时可以通过调用Array的接口push, pop, shift, unshift, splice, copyWithin, fill, reverse, sort更新Array中的数据。

装饰Date类型变量

当装饰Date类型变量时,可以观察到数据源对Date整体的赋值,以及调用Date的接口setFullYear, setMonth, setDate, setHours, setMinutes, setSeconds, setMilliseconds, setTime, setUTCFullYear, setUTCMonth, setUTCDate, setUTCHours, setUTCMinutes, setUTCSeconds, setUTCMilliseconds带来的变化。

装饰Map类型变量

当装饰Map类型变量时,可以观察到数据源对Map整体的赋值,以及调用Map的接口set, clear, delete带来的变化。

装饰Set类型变量

当装饰Set类型变量时,可以观察到数据源对Set整体的赋值,以及调用Set的接口 add, clear, delete带来的变化。

@Provider和@Consumer装饰回调函数属性用于组件之间完成行为抽象

当需要在父(祖)组件中向子组件注册回调函数时,可以使用@Provider和@Consumer装饰回调方法来实现。子组件可以调用父(祖)组件设置的回调方法将数据传递给父(祖)组件。

@Provider和@Consumer装饰复杂类型,配合@Trace一起使用

  1. @Provider和@Consumer只能观察到数据本身的变化。如果需要观察其装饰的复杂数据类型的属性变化,必须配合@Trace一起使用。
  2. 装饰内置类型:Array、Map、Set、Date时,可以观察到某些API的变化,观察能力同@Trace。

@Provider重名时,@Consumer向上查找其最近的@Provider

@Provider可以在组件树上重名,@Consumer会向上查找其最近父节点的@Provider的数据。

@Consumer在跨BuilderNode场景下和@Provider建立双向同步过程

这个还不理解,后续再整理。

说明

从API version 22开始,支持跨BuilderNode配对@Provider和@Consumer。

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

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

相关文章

鸿蒙中级课程笔记2—状态管理V2—@Monitor装饰器:状态变量修改监听

为了增强状态管理框架对状态变量变化的监听能力,开发者可以使用Monitor装饰器对状态变量进行监听。 Monitor提供了对V2状态变量的监听。在阅读本文档前,建议提前阅读:ComponentV2,ObservedV2和Trace,Local。 说明 M…

鸿蒙中级课程笔记2—状态管理V2—@Computed装饰器:计算属性

当开发者使用相同的计算逻辑重复绑定在UI上时,为了防止重复计算,可以使用Computed计算属性。计算属性中的依赖的状态变量变化时,只会计算一次。这解决了UI多次重用该属性导致的重复计算和性能问题。如下面例子。 Computed get sum() {return…

鸿蒙中级课程笔记2—状态管理V2—@Local

Local装饰器:组件内部状态 为了实现对ComponentV2装饰的自定义组件中变量变化的观测,开发者可以使用Local装饰器装饰变量。 在阅读本文档前,建议提前阅读:ComponentV2。常见问题请参考组件内状态变量常见问题。 说明 从API ve…

鸿蒙中级课程笔记2—状态管理V2—@Param

为了增强子组件接受外部参数输入的能力,开发者可以使用Param装饰器。 Param不仅可以接受组件外部输入,还可以接受Local的同步变化。在阅读本文档前,建议提前阅读:Local。 说明 从API version 12开始,在ComponentV2装…

鸿蒙中级课程笔记2—状态管理V2—@Once、@Event

Once:初始化同步一次 想要实现仅从外部初始化一次且不接受后续同步变化的能力,可以使用Once装饰器搭配Param装饰器。 阅读本文档前,请先阅读Param。 说明 从API version 12开始,在ComponentV2装饰的自定义组件中支持使用Once装…

2026广安种植牙优质机构推荐榜 高性价比之选

2026广安种植牙优质机构推荐榜 高性价比之选一、行业背景与评测依据据《2026中国口腔医疗行业发展白皮书》数据显示,我国45岁以上人群缺牙率达63.2%,65岁以上人群全口缺牙率超10%,口腔修复需求呈逐年攀升态势。 川东…

深入 Pinia 工作原理:响应式核心、持久化机制与缓存策略 - 教程

深入 Pinia 工作原理:响应式核心、持久化机制与缓存策略 - 教程pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "C…

构建AI Agent的自适应学习系统

构建AI Agent的自适应学习系统 关键词:AI Agent、自适应学习系统、机器学习、强化学习、神经网络 摘要:本文旨在深入探讨构建AI Agent的自适应学习系统这一前沿技术领域。通过详细阐述自适应学习系统的核心概念、算法原理、数学模型,结合项目实战案例,展示如何实现一个高效…

软件测试之单元测试

所谓单元测试指,指的是对软件中最小可测试单元开展细致的检查与验证工作。 具体而言,它主要用于检验单个类的准确性,确保其功能符合预期。 单元测试与集成测试、系统测试存在显著差异。它是软件开发流程中前置的测试环节,规模最…

京城爱加陪诊官方电话声明

为保障广大客户的合法权益,杜绝虚假信息误导,现就京城爱加陪诊(以下简称“我方”)官方联系电话事宜郑重声明如下: 我方唯一官方咨询及服务预约电话为:010-53656582。该电话为客户对接陪诊咨询、需求登记、服务沟…

如何高效阅读学术文献:硕士研究生完全指南

如何高效阅读学术文献:硕士研究生完全指南Posted on 2026-01-24 20:05 steve.z 阅读(0) 评论(0) 收藏 举报如何高效阅读学术文献:硕士研究生完全指南"What I cannot create, I do not understand." —…

windows版中间件启动 - 详解

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

实用指南:我在CSDN学MYSQL之----数据库基本概念和基本知识(上)

实用指南:我在CSDN学MYSQL之----数据库基本概念和基本知识(上)2026-01-24 20:04 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !im…

从0到1!AI提示工程架构师助力智能营销腾飞

从0到1!AI提示工程架构师助力智能营销腾飞 一、当智能营销遇上“卡脖子”:我们需要什么样的AI桥梁? 凌晨3点,某美妆品牌的营销总监盯着电脑屏幕上的12% email打开率发愁——这是第8次调整文案了,可用户依然对千篇一律…

华为MetaERP实现智能高效排产的核心是通过人工智能、大数据、数字孪生等技术与传统ERP生产计划模块深度融合,构建动态优化、实时响应的排产体系

华为MetaERP实现智能高效排产的核心是通过人工智能、大数据、数字孪生等技术与传统ERP生产计划模块深度融合,构建动态优化、实时响应的排产体系。以下是其关键实现路径:1. 基于AI的智能排产引擎多目标优化算法:综合考虑订单交期、产能利用率、…

一文读懂AI产品经理:职责、技能与学习路径全攻略,如何成为AI产品经理?

本文详细介绍了AI产品经理的定义、职责、类型及与传统互联网产品经理的区别,强调技术理解能力成为AI产品经理的核心门槛。文章分析了AI产品经理必备的算法理解、系统架构、数据分析和业务转化等能力,并为在校生和传统产品经理提供了转型路径。最后提供了…

收藏级干货:DeepSeek Engram架构解析:大模型语言理解的新思路

DeepSeek与北大联合发布Engram架构,将语言理解分为"推理"和"知识"两部分。通过2-Grams/3-Grams分词和Multi-Head Hash存储短语,结合Context-aware Gating机制解决多义词问题。Engram将传统模型中用于"组合固定短语"的大量…

知识图谱如何提升大模型性能?WeKnora实现原理与代码解析

WeKnora通过知识图谱增强大模型检索能力,采用LLM驱动实体和关系抽取,构建文档块关系网络。系统支持并发处理,使用PMIStrength混合算法计算关系权重,实现直接关联和间接关联查询,并提供可视化展示。这一GraphRAG方案解决…

大模型训练项目如何落地:完整流程与实战技巧

本文详解大模型训练三阶段(预训练、SFT微调、强化学习)及AI训练师工作。重点讲解项目落地流程:需求承接、标注规则制定(安全性、指令遵循、准确性等维度)、数据筛选与标注管理、质量控制与迭代。以SFT项目为例&#xf…

AI产品经理vs传统产品经理:大模型时代必备技能与学习路线

本文详细介绍了AI产品经理与传统产品经理的区别,强调"懂技术"是AI产品经理的必要条件。文章阐述了AI产品经理的职责、类型(软件/硬件产品经理)、必备技能(技术能力、数据分析、业务sense)以及成为路径。最后…