HarmonyOS 鸿蒙Next ArkTS语言教程入门学习第17天,@Provide装饰器和@Consume装饰器与后代组件双向同步
HarmonyOS 鸿蒙Next ArkTS语言教程入门学习第17天,@Provide装饰器和@Consume装饰器与后代组件双向同步 1、@Provide装饰器和@Consume装饰器:与后代组件双向同步
@Provide和@Consume,应用于与后代组件的双向数据同步,应用于状态数据在多个层级之间传递的场景。不同于上文提到的父子组件之间通过命名参数机制传递,@Provide和@Consume摆脱参数传递机制的束缚,实现跨层级传递。
说明
从API version 9开始,这两个装饰器支持在ArkTS卡片中使用。
2、概述
@Provide/@Consume装饰的状态变量有以下特性:
- @Provide装饰的状态变量自动对其所有后代组件可用,即该变量被“provide”给他的后代组件。由此可见,@Provide的方便之处在于,开发者不需要多次在组件之间传递变量。
- 后代通过使用@Consume去获取@Provide提供的变量,建立在@Provide和@Consume之间的双向数据同步,与@State/@Link不同的是,前者可以在多层级的父子组件之间传递。
- @Provide和@Consume可以通过相同的变量名或者相同的变量别名绑定,变量类型必须相同。
@Provide和@Consume通过相同的变量名或者相同的变量别名绑定时,@Provide修饰的变量和@Consume修饰的变量是一对多的关系。
不允许在同一个自定义组件内,包括其子组件中声明多个同名或者同别名的@Provide装饰的变量。
3、装饰器说明
@State的规则同样适用于@Provide,差异为@Provide还作为多层后代的同步源。
@Provide变量装饰器 | 说明 |
---|---|
装饰器参数 | 别名:常量字符串,可选。 如果指定了别名,则通过别名来绑定变量;如果未指定别名,则通过变量名绑定变量。 |
同步类型 | 双向同步。 从@Provide变量到所有@Consume变量以及相反的方向的数据同步。双向同步的操作与@State和@Link的组合相同。 |
允许装饰的变量类型 | Object、class、string、number、boolean、enum类型,以及这些类型的数组。嵌套类型的场景请参考观察变化。 不支持any,不支持简单类型和复杂类型的联合类型,不允许使用undefined和null。 必须指定类型。@Provide变量的@Consume变量的类型必须相同。 说明 不支持Length、ResourceStr、ResourceColor类型,Length、ResourceStr、ResourceColor为简单类型和复杂类型的联合类型。 |
被装饰变量的初始值 | 必须指定。 |
@Consume变量装饰器 | 说明 |
---|---|
装饰器参数 | 别名:常量字符串,可选。 如果提供了别名,则必须有@Provide的变量和其有相同的别名才可以匹配成功;否则,则需要变量名相同才能匹配成功。 |
同步类型 | 双向:从@Provide变量(具体请参见@Provide)到所有@Consume变量,以及相反的方向。双向同步操作与@State和@Link的组合相同。 |
允许装饰的变量类型 | Object、class、string、number、boolean、enum类型,以及这些类型的数组。嵌套类型的场景请参考观察变化。 不支持any,不允许使用undefined和null。 必须指定类型。@Provide变量的@Consume变量的类型必须相同。 说明 @Consume装饰的变量,在其父节点或者祖先节点上,必须有对应的属性和别名的@Provide装饰的变量。 |
被装饰变量的初始值 | 无,禁止本地初始化。 |
4、变量的传递/访问规则说明
@Provide传递/访问 | 说明 |
---|---|
从父组件初始化和更新 | 可选,允许父组件中常规变量、@State、@Link、@Prop、@Provide、@Consume、@ObjectLink、@StorageLink、@StorageProp、@LocalStorageLink和@LocalStorageProp装饰的变量装饰变量初始化子组件@Provide。 |
用于初始化子组件 | 允许,可用于初始化@State、@Link、@Prop、@Provide。 |
和父组件同步 | 否。 |
和后代组件同步 | 和@Consume双向同步。 |
是否支持组件外访问 | 私有,仅可以在所属组件内访问。 |
@Consume传递/访问 | 说明 |
---|---|
从父组件初始化和更新 | 禁止。通过相同的变量名和alias(别名)从@Provide初始化。 |
用于初始化子组件 | 允许,可用于初始化@State、@Link、@Prop、@Provide。 |
和祖先组件同步 | 和@Provide双向同步。 |
是否支持组件外访问 | 私有,仅可以在所属组件内访问 |
5、观察变化和行为表现
观察变化
- 当装饰的数据类型为boolean、string、number类型时,可以观察到数值的变化。
- 当装饰的数据类型为class或者Object的时候,可以观察到赋值和属性赋值的变化(属性为Object.keys(observedObject)返回的所有属性)。
- 当装饰的对象是array的时候,可以观察到数组的添加、删除、更新数组单元。
框架行为
6、使用场景
在下面的示例是与后代组件双向同步状态@Provide和@Consume场景。当分别点击CompA和CompD组件内Button时,reviewVotes 的更改会双向同步在CompA和CompD中。
@Component
struct CompD {
[@Consume](/user/Consume) reviewVotes: number;
build() {
Column() {
Text(`reviewVotes(${this.reviewVotes})`)
Button(`reviewVotes(${this.reviewVotes}), give +1`)
.onClick(() => this.reviewVotes += 1)
}
.width('50%')
}
}
@Component
struct CompC {
build() {
Row({ space: 5 }) {
CompD()
CompD()
}
}
}
@Component
struct CompB {
build() {
CompC()
}
}
@Entry
@Component
struct CompA {
[@Provide](/user/Provide) reviewVotes: number = 0;
build() {
Column() {
Button(`reviewVotes(${this.reviewVotes}), give +1`)
.onClick(() => this.reviewVotes += 1)
CompB()
}
}
}
更多关于HarmonyOS 鸿蒙Next ArkTS语言教程入门学习第17天,@Provide装饰器和@Consume装饰器与后代组件双向同步的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html
@Provide 和 @Consume 是 HarmonyOS ArkTS 语言中用于实现组件间数据双向同步的装饰器。@Provide 装饰器用于在父组件中定义提供数据的属性,而 @Consume 装饰器用于在子组件中定义消费数据的属性。通过这两个装饰器,父组件和子组件之间可以实现数据的双向绑定。
具体来说,@Provide 装饰器标记的属性会自动将数据传递给所有使用 @Consume 装饰器标记的对应属性。当 @Provide 装饰的属性值发生变化时,所有 @Consume 装饰的属性值也会同步更新。反之,当 @Consume 装饰的属性值发生变化时,@Provide 装饰的属性值也会同步更新。
例如,父组件中定义了一个 @Provide 装饰的属性 [@Provide](/user/Provide) message: string = 'Hello'
,子组件中定义了一个 @Consume 装饰的属性 [@Consume](/user/Consume) message: string
。当父组件中的 message
值发生变化时,子组件中的 message
值也会自动更新;同样,当子组件中的 message
值发生变化时,父组件中的 message
值也会自动更新。
这种机制使得组件间的数据同步更加简洁和高效,特别是在复杂的组件树结构中,能够减少手动传递和更新数据的繁琐操作。
更多关于HarmonyOS 鸿蒙Next ArkTS语言教程入门学习第17天,@Provide装饰器和@Consume装饰器与后代组件双向同步的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html
在HarmonyOS的ArkTS语言中,@Provide
和@Consume
装饰器用于实现组件之间的双向数据绑定。@Provide
装饰器用于在父组件中提供一个可被后代组件消费的数据源,而@Consume
装饰器则用于在后代组件中消费这个数据源。当@Provide
装饰的数据发生变化时,所有使用@Consume
装饰的组件会自动更新,反之亦然。这种机制简化了组件间的数据传递和同步,提高了开发效率。例如,父组件中的@Provide
数据变化会自动更新所有子组件中的@Consume
数据,确保数据一致性。