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如何结合使用
350浏览 • 1回复 待解决
ListItemGroup Lazyforeach结合场景
566浏览 • 1回复 待解决
ListItemGroup能跟LazyForEach搭配使用吗
585浏览 • 1回复 待解决
HarmonyOS LazyForEach
109浏览 • 1回复 待解决
LazyForEach如何添加数据?
1741浏览 • 1回复 待解决
panGesture结合动画实现fling效果
569浏览 • 1回复 待解决
LazyForEach的使用限制有哪些?
166浏览 • 1回复 待解决
tabs结合scroll实现吸顶效果
797浏览 • 1回复 待解决
Refresh结合lottie实现下拉刷新动画
742浏览 • 1回复 待解决
websocket结合php做数据实时展示页面
2470浏览 • 1回复 待解决
lazyforeach替换数据源解决方案
358浏览 • 1回复 待解决
使用LazyForEach懒加载列表相关问题
549浏览 • 1回复 待解决