HarmonyOS 鸿蒙Next List控件怎么实现从底部开始加载数据

发布于 1周前 作者 bupafengyu 来自 鸿蒙OS

HarmonyOS 鸿蒙Next List控件怎么实现从底部开始加载数据

目前在开发聊天页面。最后一条消息要显示在最下面,一进入页面加载数据后,要滚动list到最下面,会出现闪烁,有没有类似android的

LinearLayoutManager manager = new LinearLayoutManager(getActivity());
manager.setStackFromEnd(true);
recyclerView.setLayoutManager(manager);

这种api?一下就搞定,哈哈


更多关于HarmonyOS 鸿蒙Next List控件怎么实现从底部开始加载数据的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html

9 回复
[@Entry](/user/Entry)
[@Component](/user/Component)
struct Chat {
// 这个列表代表聊天内容,每次发送和接收消息时,把聊天内容加入这个列表
// 当监听到列表发生变化时,执行函数scrollerBottom,把list滑动到最底部
[@State](/user/State) [@Watch](/user/Watch)('scrollerBottom') list: string[] = ['1','2','3']
scroller: Scroller = new Scroller()

scrollerBottom() {
this.scroller.scrollEdge(Edge.Bottom)
}

build() {
// initialIndex代表列表生成时,从第几个索引值开始展示,选择最后一个索引值,就实现了显示最底部的消息
// scroller代表绑定滚动事件,配合list监听,实现发送和接收消息,都能滚动到最底部
List({ initialIndex: this.list.length - 1, scroller: this.scroller }) {
ForEach(this.list, (item: string) => {
ListItem() {
Text(item)
}
})
}
.width('100%')
.height('100%')
}
}

更多关于HarmonyOS 鸿蒙Next List控件怎么实现从底部开始加载数据的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


聊天页面我开发过了,针对进入页面,list滚到到底部的问题,我是这么解决的,您看一下

大佬请教一下,如果聊天页面有很多种ViewType,还有些item 还分为父布局(接收者、发送者) ,里面还根据类型套一个子布局,这种怎么处理呢

请问下这个问题解决了吗, 碰到了一样的问题

图片闪烁可能是没添加Image().syncLoad(true)属性 参考:https://developer.huawei.com/consumer/cn/blog/topic/03154617617506006

List 组件 使用 scroller 控制滚到列表 length - 1 项目,加上平滑滚动

什么叫平滑滚动 setTimeout(() => { this.listScroller.scrollToIndex(this.dataSource.totalCount() - 1, false) }, time === undefined ? 250 : time) 有时候会没有滚到底,差一点点,因为上面消息有图片,图片会动态变化高宽

new Scroller().scrollToIndex(this.list.length - 1, true)

第二个参数 设置滑动到列表项在列表中的索引值时是否有动效 true表示有动效,false表示没有动效。 默认值:false。

在HarmonyOS (鸿蒙) 开发中,如果你想要让Next List控件(通常指列表控件,如ListContainerRecyclerView等,具体名称可能根据鸿蒙版本或组件库有所差异)从底部开始加载数据,你可以通过以下几种方式来实现:

  1. 数据顺序调整:首先,确保你的数据源列表是按照你希望从底部开始展示的顺序排列的。例如,如果你想要最新的数据项出现在列表的底部,那么你需要确保在添加新数据到列表时,是将它们添加到列表的开头,并在渲染时反转列表的顺序。

  2. 列表滚动控制:在数据加载完成后,通过调用列表控件的滚动方法(如scrollToPositionsmoothScrollToPosition),将列表滚动到最后一个可见位置。这通常意味着你需要先计算出最后一个可见项的位置(可能是列表的总长度减去屏幕能显示的项数)。

  3. 使用布局管理器:如果Next List控件支持自定义布局管理器(如RecyclerViewLayoutManager),你可以通过实现自定义的LinearLayoutManager并覆盖其相关方法,来控制列表的初始滚动位置。

  4. 监听数据变化:如果数据是动态加载的,确保在数据更新后,调用滚动到末尾的方法。

如果问题依旧没法解决请联系官网客服,官网地址是:https://www.itying.com/category-93-b0.html 。注意,由于Next List并非鸿蒙官方直接提供的标准控件名,上述建议可能需要根据你的具体控件类型进行调整。

回到顶部