List 的下拉加载如何回滚到当前展示位置

list组件下拉加载头顶元素,希望加载完之后,还是定位在刷新前的元素上面。

HarmonyOS
2024-06-11 23:25:14
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
chmqn

onDataReloaded 会重新加载列表导致,可以给List添加scroller控制器,将列表跳回原先所在位置this.scroller.scrollToIndex(index值,false不添加动效,ScrollAlign.START)。

示例:

@Entry 
@Component 
struct RefreshDemo { 
  @State isRefreshing: boolean = false 
  @State arr: String[] = ['0', '1', '2', '3', '4','5','6','7','8','9','10'] 
  private listScroller: Scroller = new Scroller(); 
 
  build() { 
    Column() { 
      Refresh({ refreshing: $$this.isRefreshing}) { 
        List({scroller: this.listScroller}) { 
          ForEach(this.arr, (item: string) => { 
            ListItem() { 
              Text('' + item) 
                .width('100%').height(100).fontSize(16) 
                .textAlign(TextAlign.Center).borderRadius(10).backgroundColor(0xFFFFFF) 
            } 
          }, (item: string) => item) 
        } 
        .onScrollIndex((first: number) => { 
          console.info(first.toString()) 
        }) 
        .width('100%') 
        .height('100%') 
        .divider({strokeWidth:1,color:Color.Yellow,startMargin:10,endMargin:10}) 
        .scrollBar(BarState.Off) 
      } 
      .onRefreshing(() => { 
        setTimeout(() => { 
          this.isRefreshing = false 
        }, 2000) 
        this.arr.unshift('11') 
        this.arr.unshift('12') 
        this.listScroller.scrollToIndex(2) 
      }) 
      .backgroundColor(0x89CFF0) 
    } 
  } 
}
分享
微博
QQ
微信
回复
2024-06-12 23:42:09
相关问题
Scroll子组件展示位置如何调整
708浏览 • 1回复 待解决
下拉刷新和上拉加载API为9sdk
1337浏览 • 1回复 待解决
WebView页面加载错误调能力。
291浏览 • 1回复 待解决
lottile动画加载完成调不调用
457浏览 • 1回复 待解决
如何屏蔽List滑动事件
827浏览 • 1回复 待解决