在开发中 经常会遇到长列表、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,就开启了
本人用这方式暂未发现明显问题,谨此记录一下,若有误导,欢迎指正