Rumah >hujung hadapan web >tutorial js >Komponen Boleh Diakses: Penomboran
Hari ini kita akan melihat cara membuat penomboran dari awal dan menjadikannya boleh diakses dan boleh digunakan semula. Saya harap ia membantu anda dan tinggalkan saya komen anda di penghujung siaran!
Github: https://github.com/micaavigliano/accessible-pagination
Projek: 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, } };
Untuk halaman boleh diakses, kita mesti mengambil kira perkara berikut:
aria-pointset digunakan untuk mengira kedudukan item dalam semua item pada halaman. Pembaca skrin akan mengumumkannya seperti berikut:
Untuk mencapai ini, kami akan kodkannya seperti berikut:
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, } };
Apabila halaman berhenti dimuatkan, kami akan menetapkan mesej baharu dengan Halaman semasa kami dan panjang tatasusunan baharu yang kami muatkan.
Sekarang ya! Mari lihat bagaimana kod itu distrukturkan dalam fail penomboran.tsx
Komponen memerlukan lima prop
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); } };
Untuk penomboran kami menjadi hidup, kami memerlukan satu langkah lagi, mencipta tatasusunan yang akan kami ulangi dalam senarai kami! Untuk itu kita mesti ikuti langkah berikut:
Tatasusunan ini adalah yang akan kami lalui untuk mendapatkan senarai item dalam halaman kami seperti berikut:
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, } };
Dan inilah cara untuk membuat penomboran yang boleh diguna semula dan boleh diakses! Secara peribadi, saya belajar cara membuat halaman dari awal kerana saya terpaksa melaksanakannya dalam pengekodan langsung. Saya harap pengalaman saya akan membantu kerjaya anda dan anda boleh melaksanakan dan juga memperbaikinya!
Salam,
Mica<3
Atas ialah kandungan terperinci Komponen Boleh Diakses: Penomboran. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!