在开发中 经常会遇到长列表、tab选项卡、ScrollView等各种嵌套,各种坑啊有木有
今天我遇到的是 tab选项卡里放FlatList长列表,发现每次上拉加载更多的时候onEndReached会执行两次,分页数据每次请求2页,数据也会抖动一下,这肯定不是我想要的。
然后百度、google了一下,哦嚯,原来很多人遇到,貌似是官方bug,具体怎么产生的自行百度或者看官方issues
我也找了很多别人的方法,复制粘贴梭哈一试,NM有个鸟用,闭着眼睛估计不知道从哪梭哈过来的
不过万幸的是给提供了四个新方法
onScrollBeginDrag={() => {
console.log('onScrollBeginDrag');
}}
onScrollEndDrag={() => {
console.log('onScrollEndDrag');
}}
onMomentumScrollBegin={() => {
console.log('onMomentumScrollBegin');
}}
onMomentumScrollEnd={() => {
console.log('onMomentumScrollEnd');
}}
看名字就知道大改怎么用
经过尝试,发现其实用不到那么多
我的思路很简单
滚动的时候把加载给禁了,当滚动到不足onEndReachedThreshold时,执行上拉加载
上代码