【HarmonyOS】ArkTS自定义组件如何调用通用属性?

发布时间 2023-07-27 16:24:47作者: Mayism123

【关键词】

ArkTS、通用属性、 @BuilderParam

 

【问题背景】

有个开发者使用ArkTS自定义了一个子组件AnimationButton,里面用到了装饰器 @BuilderParam,在父页面中引用的时候使用自定义组件时,使用以下方式调用:

cke_414.png

就报了这个错

cke_950.png

 

【问题分析】

开发者的想法是:既然是组件,就应该可以使用通用属性,甚至可以让自定义属于这个组件的属性,比如说增加自定义组件的点方法,可以CustomComponent().customProp(true)。但是当前自定义组件使用{}传递BuilderParam后,要自定义构建函数(@Builder装饰的方法)进行初始化,且不再支持调用通用属性,之前未识别到这个场景,开发人员说后续会修复;而自定义组件调用自身的方法,框架目前是不支持的。

 

【解决方案】
当前自定义组件使用{}传递BuilderParam后,不再支持调用通用属性,但是可以通过自定义构建函数(@Builder装饰的方法)初始化来实现,具体代码如下:
子组件

enum SpringEffect {
  small = 0.95,
  medium = 0.9,
  large = 0.8
}
@Component
struct AnimationButton {
  @State effect: SpringEffect = SpringEffect.medium
  @BuilderParam closer: () => void;
  @State sizeScale: number = 1;
  build() {
    Column() {
      this.closer()
    }
    .scale({
      x: this.sizeScale,
      y: this.sizeScale
    })
    .animation({
      duration: 300,
      curve: Curve.Friction
    })
    .onTouch(event => {
      if (event.type === TouchType.Down) {
        this.sizeScale = this.effect
      } else if (event.type === TouchType.Up) {
        this.sizeScale = 1
      }
    })
  }
}
export { AnimationButton, SpringEffect }

父页面

import { AnimationButton } from './Page1'
@Builder function specificParam(label: string = '未选择') {
  Column() {
    Text(label)
      .fontSize(24)
      .fontColor(Color.White)
      .textAlign(TextAlign.Center)
      .padding({top: 8, bottom: 8})
      .width('100%')
      .borderRadius(30)
      .backgroundColor(0x0066ff)
      .opacity(0.7)
  }
}

@Entry
@Component
struct HbuildParam {
  build() {
    Column() {
      // 用父组件自定义构建函数初始化子组件@BuildParam装饰的方法。
      AnimationButton({closer: specificParam})
    }
  }
}

示例效果如下:

cke_4464.png

 

【相关参考】

@BuilderParam装饰器:引用@Builder函数: ​zh-cn/application-dev/quick-start/arkts-builderparam.md · OpenHarmony/docs - Gitee.com