Heim >Web-Frontend >js-Tutorial >Zugängliche Komponenten: Paginierung
Heute werden wir sehen, wie man eine Paginierung von Grund auf erstellt und sie zugänglich und wiederverwendbar macht. Ich hoffe, es hilft dir und hinterlasse mir deine Kommentare am Ende des Beitrags!
Github: https://github.com/micaavigliano/accessible-pagination
Projekt: https://accessible-pagination.vercel.app/
const useFetch = <T,>(url: string, currentPage: number = 0, pageSize: number = 20) => { const [data, setData] = useState<T | null>(null); const [loading, setLoading] = useState<boolean>(true); const [error, setError] = useState<boolean>(false); useEffect(() => { const fetchData = async() => { setLoading(true); setError(false); try { const response = await fetch(url); if (!response.ok) { throw new Error('network response failed') } const result: T = await response.json() as T; setData(result) } catch (error) { setError(true) } finally { setLoading(false); } }; fetchData() }, [url, currentPage, pageSize]); return { data, loading, error, } };
Damit eine Seite zugänglich ist, müssen wir die folgenden Punkte berücksichtigen:
aria-pointset wird verwendet, um die Position des Elements innerhalb aller Elemente auf der Seite zu berechnen. Der Screenreader kündigt es wie folgt an:
Um dorthin zu gelangen, werden wir es wie folgt codieren:
const useFetch = <T,>(url: string, currentPage: number = 0, pageSize: number = 20) => { const [data, setData] = useState<T | null>(null); const [loading, setLoading] = useState<boolean>(true); const [error, setError] = useState<boolean>(false); useEffect(() => { const fetchData = async() => { setLoading(true); setError(false); try { const response = await fetch(url); if (!response.ok) { throw new Error('network response failed') } const result: T = await response.json() as T; setData(result) } catch (error) { setError(true) } finally { setLoading(false); } }; fetchData() }, [url, currentPage, pageSize]); return { data, loading, error, } };
Wenn die Seite nicht mehr geladen wird, legen wir eine neue Nachricht mit unserer aktuellen Seite und der Länge des neuen Arrays fest, das wir laden.
Jetzt ja! Schauen wir uns an, wie der Code in der Datei pagination.tsx
aufgebaut istFür die Komponente sind fünf Requisiten erforderlich
const [statusMessage, setStatusMessage] = useState<string>(""); useEffect(() => { window.scrollTo({ top: 0, behavior: 'smooth' }); if (!loading) { setStatusMessage(`Page ${currentPage} loaded. Displaying ${data?.near_earth_objects.length || 0} items.`); } }, [currentPage, loading]);
interface PaginationProps { currentPage: number; totalPages: number; nextPage: () => void; prevPage: () => void; goToPage: (page: number) => void; }
const handlePageChange = (newPage: number) => { setCurrentPage(newPage); }; const nextPage = () => { if (currentPage < totalPages) { handlePageChange(currentPage + 1); } };
const prevPage = () => { if (currentPage > 1) { handlePageChange(currentPage - 1); } };
Damit unsere Paginierung zum Leben erweckt wird, benötigen wir noch einen weiteren Schritt: die Erstellung des Arrays, das wir in unserer Liste iterieren werden! Dazu müssen wir die folgenden Schritte befolgen:
Dieses Array werden wir durchgehen, um die Liste der Elemente auf unserer Seite wie folgt zu erhalten:
const useFetch = <T,>(url: string, currentPage: number = 0, pageSize: number = 20) => { const [data, setData] = useState<T | null>(null); const [loading, setLoading] = useState<boolean>(true); const [error, setError] = useState<boolean>(false); useEffect(() => { const fetchData = async() => { setLoading(true); setError(false); try { const response = await fetch(url); if (!response.ok) { throw new Error('network response failed') } const result: T = await response.json() as T; setData(result) } catch (error) { setError(true) } finally { setLoading(false); } }; fetchData() }, [url, currentPage, pageSize]); return { data, loading, error, } };
Und so erstellen Sie eine wiederverwendbare und zugängliche Paginierung! Ich persönlich habe gelernt, wie man eine Seite von Grund auf erstellt, weil ich sie in Live-Codierung umsetzen musste. Ich hoffe, dass meine Erfahrung für Ihre Karriere hilfreich sein wird und Sie sie umsetzen und sogar verbessern können!
Grüße,
Glimmer<3
Das obige ist der detaillierte Inhalt vonZugängliche Komponenten: Paginierung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!