React 滚动加载--ahooks--useInfiniteScroll

本文介绍了如何在React项目中利用ahooks库的useInfiniteScroll实现滚动加载功能。useInfiniteScroll封装了无限滚动逻辑,通过传入异步服务函数和服务选项来获取和合并数据。内容包括基本用法、参数解析、API说明及示例代码,重点解释了data、loading、loadingMore和noMore等关键属性的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在此之前:您可以移步去官网ahooks了解详情

useInfiniteScroll基本介绍

useInfiniteScroll 封装了常见的无限滚动逻辑。

const { data, loading, loadingMore, loadMore } = useInfiniteScroll(service);

useInfiniteScroll 的第一个参数 service 是一个异步函数,对这个函数的入参和出参有如下约定:

  1. service 返回的数据必须包含 list 数组,类型为 { list: any[], ...rest }
  2. service 的入参为整合后的最新 data

假如第一次请求返回数据为 { list: [1, 2, 3], nextId: 4 }, 第二次返回的数据为 { list: [4, 5, 6], nextId: 7 }, 则我们会自动合并 list,整合后的的 data 为 { list: [1, 2, 3, 4, 5, 6], nextId: 7 }

注:这里官方说了对于返回的字段是list,才会帮你进行合并,所以可以跟后端的同学商量返回的数组数据用list做属性名,或者你也可以拿到后端的数据自己生成list属性名。

参数--(参照官网)

Result

参数 说明 类型
data service 返回的数据,其中的 list 属性为聚合后数据 TData | undefined
loading 是否正在进行首次请求 boolean
loadingMore 是否正在进行更多数据请求 boolean
noMore 是否没有更多数据了,配置 options.isNoMore 后生效 boolean
loadMore 加载更多数据,会自动捕获异常,通过 options.onError 处理 () =
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值