React Pagination Hook
Drop-in typescript code to handle pagination properly with react hooks and URL query parameters
This short hook leverages several best practices:
- use an URL query parameter to persist the current state
- better UX when reloading the website
- better SEO since all pages are crawlable
- leverage
history.replace()
to preserve clean browser history - API surface is the same as
useState()
- graceful fallback to
1
if there is no page parameter set currently
import { useHistory, useLocation } from "react-router-dom";
export const usePagination = (): [number, (page: number) => void] => {
const { pathname, search } = useLocation();
const params = new URLSearchParams(search);
const page = parseInt(params.get('page') || "1");
const history = useHistory();
const setPage = (newPage = 1) => {
params.set('page', newPage.toString())
history.replace({ pathname, search: params.toString() });
}
return [page, setPage]
}
Linked Technologies
What it's made of
data:image/s3,"s3://crabby-images/1f981/1f981d3a26871787788fa8f759fecaa8dac40b34" alt="illustration of Javascript"
Javascript
Power up your web projects! Essential for dynamic interactions and seamless user experiences. A must-have for every developer's toolkit.
data:image/s3,"s3://crabby-images/be7c3/be7c3c6265cafa5e788eb27b804e26d9cd57b62a" alt="illustration of React"
React
React.js: Build dynamic and responsive UIs with ease. Perfect for indie hackers looking to create scalable, efficient web applications!
data:image/s3,"s3://crabby-images/b19b3/b19b36bb24e5852034ffa8241dae525ce4c7cbdd" alt="illustration of Typescript"
Typescript
Supercharge your JavaScript with strong typing. Ensure more reliable code and robust applications with this scalable, developer-friendly language.
Linked Categories
Where it's useful
data:image/s3,"s3://crabby-images/db7a3/db7a3af040bb9497c898d546c992d7c2bcf0bcc1" alt="illustration of Frontend Development"
Frontend Development
Explore the latest tools and techniques for crafting responsive designs, enhancing user interfaces, and optimizing web performance.