迫于实现一个 infiniteScroll 组件,求提供思路

2018-12-24 11:08:58 +08:00
 molvqingtai
我遇到这么个问题哪位大佬提供下思路
我写了一个 infiniteScroll 组件,通过监听滚动条实现,传入两个 props,一个是控制是否禁用加载的 Boolean 变量,一个是触底后要执行的 function,,现在效果是实现了,但是当手动更改数据后(排序),pageSize 不够撑满 html 的情况下,因为没有滚动条,就不会触发滚动事件
我想实现的效果是 infiniteScroll 和父组件解耦和 data 的数据无关,只要触底就加载,但是因为 pageSize 的问题我还需要传入第三个 props 做判断,大佬们提供下思路

就几行代码

1985 次点击
所在节点    程序员
5 条回复
tinytin
2018-12-24 12:45:01 +08:00
用 getBoundingClientRect
mmmfj
2018-12-24 13:12:43 +08:00
这个代码图片是怎么生成的
molvqingtai
2018-12-24 13:13:52 +08:00
@mmmfj 一个插件 Carbon
edwardwo
2018-12-24 14:37:42 +08:00
listEle.addEventListener('wheel', this.infiniteScroll)
用'wheel' event, 不要用 scroll, scroll 必须有滚动条时才触发. 'wheel' 一滚动, 就触发. 在 infiniteScroll 中再判断:

scrollHeight = listEle.scrollHeight
scrollTop = listEle.scrollTop
offsetHeight = listEle.offsetHeight

if (scrollHeight === scrollTop + offsetHeight) {
this.$emit('loadMore')
}
molvqingtai
2018-12-24 16:42:46 +08:00
@edwardwo 问题解决了,感谢大佬!

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/520377

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX