HarmonyOS ListItemGroup和LazyForEach如何结合

ListItemGroup和LazyForEach如何结合,能否帮忙提供个例子

HarmonyOS
2024-08-04 14:41:31
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
失望的满天星

可参考:

@Entry 
@Component 
struct ListItemGroupExample { 
  private list: MyDataSource2 = new MyDataSource2() 
 
  @Builder 
  itemHead(text: string) { 
    Text(text) 
      .fontSize(20) 
      .backgroundColor(0xAABBCC) 
      .width("100%") 
      .padding(10) 
  } 
 
  @Builder 
  itemFoot(num: number) { 
    Text('共' + num + "节课") 
      .fontSize(16) 
      .backgroundColor(0xAABBCC) 
      .width("100%") 
      .padding(5) 
  } 
 
  aboutToAppear() { 
    for (let date = 1; date < ~~(Math.random() * 30) + 3; date++) { 
      let dayData = new dateListItem(date + "") 
      for (let index = 1; index < ~~(Math.random() * 100) + 30; index++) { 
        dayData.orderList.pushData(`hello${index}`) 
      } 
      this.list.pushData(dayData) 
    } 
  } 
 
  build() { 
    Column() { 
      List({ space: 20 }) { 
        LazyForEach(this.list, (item: dateListItem, index) => { 
          ListItemGroup({ header: this.itemHead(item.date + ""), footer: this.itemFoot(item.orderList.totalCount()) }) { 
            LazyForEach(item.orderList, (order: string, index2) => { 
              ListItem() { 
                Text(order) 
                  .onAppear(() => { 
                    console.info("appear:" + order, index2 + "") 
                  }) 
                  .width("100%") 
                  .height(60) 
                  .fontSize(20) 
                  .textAlign(TextAlign.Center) 
                  .backgroundColor(0xFFFFFF) 
              } 
            }, (item: string) => item) 
          } 
          .onAppear(() => { 
            console.info("appear:" + item, index + "") 
          }) 
          .divider({ strokeWidth: 1, color: Color.Blue }) // 每行之间的分界线 
        }) 
      } 
      .cachedCount(1) 
      .width('90%') 
      .sticky(StickyStyle.Header | StickyStyle.Footer) 
      .scrollBar(BarState.Off) 
    }.width('100%').height('100%').backgroundColor(0xDCDCDC).padding({ top: 5 }) 
  } 
}
分享
微博
QQ
微信
回复
2024-08-05 12:14:54
相关问题
ListItemGroup Lazyforeach结合场景
819浏览 • 1回复 待解决
ListItemGroup lazyforeach如何结合使用
522浏览 • 1回复 待解决
ListItemGroup能跟LazyForEach搭配使用吗
741浏览 • 1回复 待解决
HarmonyOS LazyForEach
212浏览 • 1回复 待解决
list 如何使用 lazyforeach
173浏览 • 1回复 待解决
LazyForEach如何添加数据?
1885浏览 • 1回复 待解决
HarmonyOS swiper + LazyForEach使用问题
148浏览 • 1回复 待解决
HarmonyOS lazyForeach嵌套视图问题
99浏览 • 1回复 待解决
panGesture结合动画实现fling效果
747浏览 • 1回复 待解决
tabs结合scroll实现吸顶效果
1126浏览 • 1回复 待解决