HarmonyOS 组件变量被@Link修饰,如何使用ForEach批量创建组件

class GreenButtonState {  
  width: number = 0;  
  
  constructor(width: number) {  
    this.width = width;  
  }  
}  
  
@Component  
struct GreenButton {  
  @Link greenButtonState: GreenButtonState;  
  
  build() {  
    Button('Green Button')  
      .width(this.greenButtonState.width)  
      .height(40)  
      .backgroundColor('#64bb5c')  
      .fontColor('#FFFFFF,90%')  
      .onClick(() => {  
        if (this.greenButtonState.width < 700) {  
          // 更新class的属性,变化可以被观察到同步回父组件  
          this.greenButtonState.width += 60;  
        } else {  
          // 更新class,变化可以被观察到同步回父组件  
          this.greenButtonState = new GreenButtonState(180);  
        }  
      })  
  }  
}  
  
@Component  
struct YellowButton {  
  @Link yellowButtonState: number;  
  
  build() {  
    Button('Yellow Button')  
      .width(this.yellowButtonState)  
      .height(40)  
      .backgroundColor('#f7ce00')  
      .fontColor('#FFFFFF,90%')  
      .onClick(() => {  
        // 子组件的简单类型可以同步回父组件  
        this.yellowButtonState += 40.0;  
      })  
  }  
}  
  
@Entry  
@Component  
struct ShufflingContainer {  
  build() {  
    Column() {  
      Swiper(this.swiperController) {  
        ForEach(this.data, (item: GreenButtonState , index: number) => {  
          这里如何批量创建GreenButton 和YellowButton  
        })  
      }  
    }  
  }  
}  
}
HarmonyOS
2024-09-25 12:26:35
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
FengTianYa

在初始化渲染时,foreach会加载数据源的所有数据,并为每个数据创建对应的组件,然后将其挂载到渲染树上,如果数据源非常大或有特定的性能需求,建议使用lazyForEach组件,参考:https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V5/arkts-rendering-control-lazyforeach-0000001820879609-V5#ZH-CN_TOPIC_0000001834460352__idatasource%E7%B1%BB%E5%9E%8B%E8%AF%B4%E6%98%8E

分享
微博
QQ
微信
回复
2024-09-25 18:18:39
相关问题
组件与子组件使用@Link双向同步
926浏览 • 1回复 待解决
django怎么解决批量创建用户问题?
4746浏览 • 1回复 待解决
组件属性width是否支持使用变量定义
450浏览 • 1回复 待解决
LocalStorageLink修饰变量会自动保存
977浏览 • 1回复 待解决
var能否修饰ArkTS中的变量
501浏览 • 1回复 待解决