鸿蒙_自定义组件包含多个引用自定义构建函数@BuilderParam时的用法

有时候我们为了增加自定义组件的灵活性,可能放置多个引用自定义构建函数(通过@BuilderParam修饰的变量,指向一个自定义构建函数),那么和只有一个时有什么区别呢,我们新建一个页面来测试一下:

TypeScript 复制代码
@Entry
@Component
struct TestBuilderParamInMultiComponent {
  @State message: string = 'Test @BuilderParam In Multiple Component';

  //编写一个自定义构建函数,用于替换自定义组件的部分UI
  @Builder
  builderInMainPage() {
    Row() {
      Text('在父组件中定义、').fontColor(Color.Green)
      Text('自定义构建函数作为参数')
    }
  }

  build() {
    Column() {
      Text(this.message)
        .margin({ bottom: 10 })
        .fontSize(15)
        .fontWeight(FontWeight.Bold)

      //不传参(如果自定义组件内的builderParamInComp加了@Require不传会报错)
      CompWithTwoBuilderParam()

      // 普通传参1个
      CompWithTwoBuilderParam({
        builderParam2InComp: this.builderInMainPage
      })

      // 普通传参2个
      CompWithTwoBuilderParam({
        builderParam1InComp: this.builderInMainPage,
        builderParam2InComp: this.builderInMainPage
      })

      //尾随闭包不可用,会报错
      /*CompWithTwoBuilderParam() {
        Row() {
          Text('尾随闭包不适用多@BuilderParam参数')
        }
      }*/

    }
    .padding(10)
    .height('100%')
    .width('100%')
  }
}

//自定义组件
@Component
struct CompWithTwoBuilderParam {
  //自定义构建函数1
  @Builder
  builder1InComp() {
    Text('1、自定义构建函数1的默认内容')
  }
  //自定义构建函数2
  @Builder
  builder2InComp() {
    Text('2、自定义构建函数2的默认内容')
  }

  //引用自定义构建函数1(把自定义构建函数整体作为一个参数)
  //@Require
  @BuilderParam
  builderParam1InComp: () => void = this.builder1InComp;

  //引用自定义构建函数2
  //@Require
  @BuilderParam
  builderParam2InComp: () => void = this.builder2InComp;

  build() {
    Column({ space: 10 }) {
      Text('这是一个自定义组件').fontWeight(FontWeight.Bold)
      this.builderParam1InComp()
      this.builderParam2InComp()
    }
    .padding(10)
    .width('100%')
    .margin({ bottom: 10 })
    .border({ width: 1, color: Color.Blue })
  }
}

通过测试我们发现,在有多个@BuilderParam修饰的参数时,之前的尾随闭包方式不可用了,因为尾随闭包在调用自定义组件时,在后边大括号内直接写UI组件,是不指定参数名的,那么当参数大于1个时,就不知道该传给谁了,所以就不能再使用了。另外,如果我们在参数上没有设置@Require的必传验证,那么我们可以不传参或传部分参数,未传参的则保持默认值。


实际运行效果如下:

相关推荐
liulian091610 小时前
Flutter for OpenHarmony 跨平台开发:BMI计算器功能实战指南
flutter·华为
xmdy586613 小时前
Flutter+开源鸿蒙实战|智安盾电商溯源平台Day1 项目搭建与整体方案拆解
flutter·开源·harmonyos
nashane14 小时前
HarmonyOS 6学习:应用签名文件丢失处理与更新完全指南
学习·华为·harmonyos·harmonyos 5
笔触狂放15 小时前
【项目】基于ArkTS的老年人智能应用开发(1)
harmonyos·arkts·鸿蒙
24白菜头17 小时前
【无标题】
c++·笔记·学习·harmonyos
LeesonWong18 小时前
Neo 构建鸿蒙应用【二】:技术路线全解
harmonyos
LeesonWong18 小时前
Neo 构建鸿蒙应用【三】:实战社交应用与工程感悟
harmonyos
xmdy586619 小时前
Flutter+开源鸿蒙实战|智联邻里Day6 引入GetX全局架构+升级版下拉刷新+Toast弹窗+网络状态监听
flutter·开源·harmonyos
斯班奇的好朋友阿法法19 小时前
鸿蒙 vs iOS vs 微信小程序:开发平台全面对比
ios·微信小程序·harmonyos
xmdy586619 小时前
Flutter+开源鸿蒙实战|智联邻里Day5 闲置详情页+删除功能+下拉刷新+交互优化
flutter·开源·harmonyos