react native 中FlatList组建上拉加载onEndReached多次触发

在开发中 经常会遇到长列表、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时,执行上拉加载


上代码


                
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值