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

it2023-01-24  64

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

上代码

const [ loadFlag, setLoadFlag ] = useState(true); // 上拉加载 const onEndReached = () => { if (!loadFlag) return; ... setLoadFlag(false); } <FlatList ... onEndReachedThreshold={0.01} onEndReached={onEndReached} onScrollEndDrag={() => { setLoadFlag(true); }} />

很简单,既然会连续触发上拉加载,那就在每次上拉加载后把flag设为false,false就不执行加载 而当用户滚动结束的时候会将flag设置为true,就开启了

本人用这方式暂未发现明显问题,谨此记录一下,若有误导,欢迎指正  

最新回复(0)