Hey Folks,
Today it's time to learn how you can paginate a list with ReactQuery.
It's common to create a pagination of a list to improve the user interface of your platform if you are building a list in your application, but also to limitate the work in your API.
Using ReactQuery, building a paginate list is a piece of cake.
You have to follow 3 steps:
Create a state to save the value of the current page
Create a state to save the limit of the pages (the number of elements on every page)
Fetch the data every time the user changes one of the previous states.
But let's see an example that is easier to understand
const fetchTodos = async (
page: number,
limit: number,
signal: AbortSignal | undefined
): Promise<{
totals: number;
todos: Todo[];
}> => {
const response = await fetch(`api/tasks?_page=${page}&_limit=${limit}`, {
signal,
});
if (!response.ok) {
throw new ResponseError('Failed to fetch todos', response);
}
const todos: Todo[] = await response.json();
const totals = Number.parseInt(
response.headers.get('x-total-count') || '0',
10
);
return {
totals,
todos,
};
};
interface UseTodos {
todos: Todo[];
isLoading: boolean;
isFetching: boolean;
error?: string;
pages: number;
page: number;
setPage: Dispatch<SetStateAction<number>>;
}
export const useTodos = (): UseTodos => {
const [page, setPage] = useState<number>(1);
const [limit] = useState<number>(5);
const {
data: { todos, totals } = {
todos: [],
totals: 0,
},
isLoading,
isFetching,
error,
} = useQuery(
[QUERY_KEY.todos, page, limit],
({ signal }) => fetchTodos(page, limit, signal),
{
refetchOnWindowFocus: false,
retry: 2,
}
);
return {
todos,
isLoading,
isFetching,
error: mapError(error),
pages: Math.ceil(totals / limit),
page,
setPage,
};
};
As you can notice, the process to build a pagination with ReactQuery is very simple.
The fetch request has to contain the page and the limit (you can handle a pagination also with limit and offset if you want) and in your useQuery
you have to handle some simple stuff. First, the key of your query must include the page and limit too, second you must pass page and limit to your fetch request.
As you can see, building a paginated list with ReactQuery is really a piece of cake, but if want to dive into it don't miss my youtube video about it
I think thats all from this article; I hope you enjoyed this content!
See you soon folks
Bye Bye 👋
p.s. you can find the code of the video here
Photo by Rahul Mishra on Unsplash
Top comments (7)
Nice article! Thanks :)
Are you also planning to release a part where we can se dependent queries? I have often the case where I need to fetch data and then fetch data depending on the data of the first fetch. Since hooks can not be part of a condition or inside another hook this was always a showstopper for me and react-query. Do you have a solution for that? :)
I haven’t planned this article yet :) But now I put it in my list :)
however, in the react query documentation, there is this paragraph on dependent queries if it can help you :)
tanstack.com/query/v4/docs/react/g...
Nice stuff well done.
Thanks 🙌🏻
You are welcome
Thanks for your nice tutorial .
Thank you to you Nizam