1# \@ComponentV2装饰器:自定义组件 2 3为了在自定义组件中使用V2版本状态变量装饰器的能力,开发者可以使用\@ComponentV2装饰器装饰自定义组件。 4 5>**说明:** 6> 7>\@ComponentV2装饰器从API version 12开始支持。 8> 9>当前状态管理(V2试用版)仍在逐步开发中,相关功能尚未成熟,建议开发者尝鲜试用。 10 11 12## 概述 13 14和[\@Component装饰器](arkts-create-custom-components.md)一样,\@ComponentV2装饰器用于装饰自定义组件: 15 16- 在\@ComponentV2装饰的自定义组件中,开发者仅可以使用全新的状态变量装饰器,包括\@Local、\@Param、\@Once、\@Event、\@Provider、\@Consumer等。 17- \@ComponentV2装饰的自定义组件暂不支持组件复用、LocalStorage等现有自定义组件的能力。 18- 无法同时使用\@ComponentV2与\@Component装饰同一个struct结构。 19- \@ComponentV2支持一个可选的boolean类型参数freezeWhenInactive,来实现[组件冻结功能](arkts-custom-components-freezeV2.md)。 20 21- 一个简单的\@ComponentV2装饰的自定义组件应具有以下部分: 22 23 ```ts 24 @ComponentV2 // 装饰器 25 struct Index { // struct声明的数据结构 26 build() { // build定义的UI 27 } 28 } 29 ``` 30 31除非特别说明,\@ComponentV2装饰的自定义组件将与\@Component装饰的自定义组件保持相同的行为。 32 33## 限制条件 34 35在将\@Component装饰的自定义组件与\@ComponentV2装饰的自定义组件混合使用时,以下情况的变量传递是不允许的: 36 37- \@ComponentV2装饰的自定义组件中的非状态变量接收来自父组件传递的变量。 38 39- 将\@State、\@Prop、\@Link、\@ObjectLink、\@Provide、\@Consume、\@StorageLink、\@StorageProp、\@LocalStorageLink、\@LocalStorageProp等装饰的对象类型的变量传递给\@ComponentV2装饰的自定义组件里的\@Param、\@Event等装饰的变量。 40 41- 将被\@Local、\@Param、\@Event、\@Provider、\@Consumer等装饰的Array、Set、Map、Date类型的变量传递给\@Component装饰的自定义组件里的@State、\@Prop、\@ObjectLink、\@Provide等装饰的变量。 42 43- 在\@Component装饰的自定义组件里被@Link修饰的变量,接收来自\@ComponentV2装饰的父组件传递的变量。 44 45- 在\@Component装饰的自定义组件中使用\@State、\@Prop、\@Link、\@Provide、\@Consume、\@StorageLink、\@StorageProp、\@LocalStorageLink、\@LocalStorageProp装饰被\@ObservedV2装饰的类。 46 47- 在\@ComponentV2装饰的自定义组件中使用\@Local、\@Param、\@Event、\@Provider()、\@Consumer()装饰被\@Observed装饰的类。