call APIs with pagination
2022年5月1日小于 1 分钟
call APIs with pagination
Question
Have you ever met some APIs with pagination, and needed to recursively fetch them based on response of previous request ?
Suppose we have a /list
API, which returns an array items
.
// fetchList is provided for you
const fetchList = (since?: number) =>
Promise<{items: Array<{id: number}>}>
- for initial request, we just fetch
fetchList
. and get the last item id from response. - for next page, we need to call
fetchList(lastItemId)
. - repeat above process.
The /list
API only gives us 5 items at a time, with server-side filtering, it might be less than 5. But if none returned, it means nothing to fetch any more and we should stop.
You are asked to create a function that could return arbitrary amount of items.
const fetchListWithAmount = (amount: number = 5) { }
note
You can achieve this by regular loop, even fancier solutions with async iterators or async generators. You should try them all.
Code
// fetchList is provided for you
// const fetchList = (since?: number) =>
// Promise<{items: Array<{id: number}>}>
// you can change this to generator function if you want
const fetchListWithAmount = async (amount = 5) => {
// your code here
}