


Hai semua!
Saya telah mengusahakan cangkuk React ringan yang saya panggil useAsync yang meniru beberapa ciri penting React Query (seperti mengambil, menyimpan cache, mencuba semula, dll.) tetapi dalam bentuk yang lebih padat, pakej mudah disesuaikan. Di bawah ialah pecahan pantas tentang cara ia berfungsi secara dalaman, merujuk bahagian kod yang berkaitan. Jika anda ingin melihat keseluruhan kod, pergi ke repo:
Kod Sumber Penuh pada GitHub.
Cangkuk itu juga tersedia pada npm sebagai api-refetch.
Mengapa Membuat Cangkuk Saya Sendiri?
Walaupun React Query dan SWR adalah kedua-dua perpustakaan yang hebat, saya mahukan pendekatan yang lebih praktikal atas beberapa sebab:
Jejak Ringan
Walaupun React Query dan SWR kaya dengan ciri, ia boleh menjadi agak besar (React Query ~2.2 MB, SWR ~620 kB). api-refetch adalah sekitar 250 kB, menjadikannya sesuai untuk apl yang lebih kecil di mana saiz berkas menjadi kebimbangan besar. Cangkuk ini yang dimaksudkan untuk dipasang sebagai pergantungan perpustakaan lain (Intlayer). Akibatnya, saiz penyelesaian menjadi pertimbangan penting.Mudah Disesuaikan & Dioptimumkan
Saya memerlukan beberapa keupayaan khusus—seperti menyimpan/mengambil data daripada storan setempat dan mengurus permintaan selari menggunakan pendekatan yang mudah.
Dengan mengklon repo atau menyalin kod terus ke dalam projek anda, anda boleh menanggalkan sebarang ciri yang tidak diingini dan menyimpan hanya perkara yang anda perlukan. Ini bukan sahaja mengurangkan saiz himpunan tetapi juga meminimumkan pemaparan semula dan peningkatan yang tidak perlu, memberikan anda penyelesaian yang lebih ramping dan lebih berprestasi yang disesuaikan dengan keperluan khusus anda.Tiada Pembekal Diperlukan
Saya ingin mengelakkan Penyedia Konteks untuk menjadikan cangkuk global, dan memastikan penggunaannya semudah mungkin. Jadi saya membuat versi cangkuk berdasarkan kedai Zustand (lihat contoh di bawah).Latihan Belajar
Membina pustaka async dari awal ialah cara terbaik untuk memahami concurrency, caching dan keadaan dalaman pengurusan.
Ringkasnya, melancarkan cangkuk saya sendiri adalah peluang untuk mengasah ciri yang saya perlukan dengan tepat (dan langkau yang saya tidak perlukan) sambil memastikan perpustakaan kecil dan mudah difahami.
Ciri-ciri Dilindungi
Kail React mengurus:
- Pengurusan Pengambilan & Negeri: Mengendalikan keadaan pemuatan, ralat, kejayaan dan pengambilan.
- Caching & Storage: Menyimpan data secara pilihan (melalui keadaan React atau Zustand di bawah hud) dan menawarkan sokongan storan setempat.
- Cuba Semula & Pengesahan Semula: Had cuba semula boleh dikonfigurasikan dan selang pengesahan semula automatik.
- Pengaktifan & Pembatalan: Secara automatik mengaktifkan dan membatalkan pertanyaan bergantung pada pertanyaan atau keadaan lain. Contoh: ambil beberapa data secara automatik apabila pengguna log masuk. Dan batalkannya apabila pengguna log keluar.
- Pengambilan Pelekap Komponen Selari: Menghalang berbilang permintaan serentak untuk sumber yang sama apabila berbilang komponen dipasang serentak.
Bagaimana Kod Berfungsi
Di bawah ialah perkara utama dalam pengambilan semula api dan rujukan ringkas kepada bahagian kod yang berkaitan dalam useAsync.tsx.
1. Mengambil dan Mengendalikan Pemasangan Selari
- Coretan Kod:
// This map stores any in-progress Promise to avoid sending parallel requests // for the same resource across multiple components. const pendingPromises = new Map(); const fetch: T = async (...args) => { // Check if a request with the same key + args is already running if (pendingPromises.has(keyWithArgs)) { return pendingPromises.get(keyWithArgs); } // Otherwise, store a new Promise and execute const promise = (async () => { setQueryState(keyWithArgs, { isLoading: true }); // ...perform fetch here... })(); // Keep it in the map until it resolves or rejects pendingPromises.set(keyWithArgs, promise); return await promise; };
- Penjelasan: Di sini, kami menyimpan sebarang pengambilan berterusan dalam petaPromises yang belum selesai. Apabila dua komponen cuba mengambil sumber yang sama secara serentak (dengan mempunyai keyWithArgs yang sama), komponen kedua hanya menggunakan semula permintaan yang sedang berjalan dan bukannya membuat panggilan rangkaian pendua.
2. Pengesahan semula
- Coretan Kod:
// Handle periodic revalidation if caching is enabled useEffect( () => { if (!revalidationEnabled || revalidateTime { fetch(...storedArgsRef.current); }, revalidateTime); return () => clearTimeout(timeout); }, [ /* dependencies */ ] );
- Penjelasan: Setiap kali anda mendayakan pengesahan semula, api-refetch menyemak sama ada data cache lebih lama daripada revalidateTime yang ditentukan. Jika ya, data diambil semula secara automatik di latar belakang untuk memastikan UI anda disegerakkan tanpa pencetus manual tambahan.
3. Cuba semula Logik
- Coretan Kod:
useEffect( () => { const isRetryEnabled = errorCount > 0 && retryLimit > 0; const isRetryLimitReached = errorCount > retryLimit; if (!isEnabled || !enabled) return; // Hook is disabled if (!isRetryEnabled) return; // Retry is disabled if (isRetryLimitReached) return; // Retry limit has been reached if (!(cacheEnabled || storeEnabled)) return; // Useless to retry if caching is disabled if (isLoading) return; // Fetch is already in progress if (isSuccess) return; // Hook has already fetched successfully const timeout = setTimeout(() => { fetch(...storedArgsRef.current); }, retryTime); return () => clearTimeout(timeout); }, [ /* dependencies */ ] );
- Penjelasan: Tersilap, cangkuk mengira berapa banyak percubaan yang gagal telah berlaku. Jika ia masih di bawah retryLimit, ia secara automatik menunggu retryTime milisaat sebelum mencuba lagi. Proses ini berterusan sehingga data berjaya diambil atau had cuba semula dicapai.
4. Auto-Ambil
- Coretan Kod:
// Auto-fetch data on hook mount if autoFetch is true useEffect( () => { if (!autoFetch) return; // Auto-fetch is disabled if (!isEnabled || !enabled) return; // Hook is disabled if (isFetched && !isInvalidated) return; // Hook have already fetched or invalidated if (isLoading) return; // Fetch is already in progress fetch(...storedArgsRef.current); }, [ /* dependencies */ ] );
- Penjelasan: Dengan autoFetch ditetapkan kepada benar, cangkuk akan menjalankan fungsi async secara automatik sebaik sahaja komponen dipasang—sempurna untuk senario "fire-and-forget" di mana anda sentiasa mahu data dimuatkan.
Lihat Sumber Penuh di GitHub
Lihat kod lengkap, yang termasuk logik storan setempat, ketidaksahihan pertanyaan dan banyak lagi di sini:
- Kod Sumber Penuh
Jangan ragu untuk mencubanya, melaporkan isu atau menyumbang jika anda berminat. Sebarang maklum balas amat dihargai!
Contoh penggunaan
Pemasangan
Salin kod atau kod (repo)[https://github.com/aymericzip/api-refetch]
Atau
// This map stores any in-progress Promise to avoid sending parallel requests // for the same resource across multiple components. const pendingPromises = new Map(); const fetch: T = async (...args) => { // Check if a request with the same key + args is already running if (pendingPromises.has(keyWithArgs)) { return pendingPromises.get(keyWithArgs); } // Otherwise, store a new Promise and execute const promise = (async () => { setQueryState(keyWithArgs, { isLoading: true }); // ...perform fetch here... })(); // Keep it in the map until it resolves or rejects pendingPromises.set(keyWithArgs, promise); return await promise; };
Contoh Pantas
// Handle periodic revalidation if caching is enabled useEffect( () => { if (!revalidationEnabled || revalidateTime { fetch(...storedArgsRef.current); }, revalidateTime); return () => clearTimeout(timeout); }, [ /* dependencies */ ] );
Itu sahaja! Cubalah, dan beritahu saya bagaimana ia berlaku. Maklum balas, soalan atau sumbangan amat dialu-alukan di GitHub.
GitHub: api-refetch
Selamat pengekodan!
Atas ialah kandungan terperinci Pameran Cangkuk Ringan untuk Pengambilan & Cache Data Async dalam React. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Penjelasan terperinci mengenai kaedah penggantian rentetan javascript dan Soalan Lazim Artikel ini akan meneroka dua cara untuk menggantikan watak rentetan dalam JavaScript: Kod JavaScript dalaman dan HTML dalaman untuk laman web. Ganti rentetan di dalam kod JavaScript Cara yang paling langsung ialah menggunakan kaedah pengganti (): str = str.replace ("cari", "ganti"); Kaedah ini hanya menggantikan perlawanan pertama. Untuk menggantikan semua perlawanan, gunakan ungkapan biasa dan tambahkan bendera global g: str = str.replace (/fi

Tutorial ini menunjukkan kepada anda bagaimana untuk mengintegrasikan API carian Google tersuai ke dalam blog atau laman web anda, menawarkan pengalaman carian yang lebih halus daripada fungsi carian tema WordPress standard. Ia menghairankan mudah! Anda akan dapat menyekat carian ke y

Jadi di sini anda, bersedia untuk mempelajari semua perkara ini yang dipanggil Ajax. Tetapi, apa sebenarnya? Istilah Ajax merujuk kepada kumpulan teknologi longgar yang digunakan untuk membuat kandungan web yang dinamik dan interaktif. Istilah Ajax, yang asalnya dicipta oleh Jesse J

Siri artikel ini ditulis semula pada pertengahan 2017 dengan maklumat terkini dan contoh segar. Dalam contoh JSON ini, kita akan melihat bagaimana kita dapat menyimpan nilai mudah dalam fail menggunakan format JSON. Menggunakan notasi pasangan nilai utama, kami boleh menyimpan apa-apa jenis

Leverage JQuery untuk Layouts Laman Web yang mudah: 8 Plugin Essential JQuery memudahkan susun atur laman web dengan ketara. Artikel ini menyoroti lapan plugin jQuery yang kuat yang menyelaraskan proses, terutamanya berguna untuk penciptaan laman web manual

Mata teras Ini dalam JavaScript biasanya merujuk kepada objek yang "memiliki" kaedah, tetapi ia bergantung kepada bagaimana fungsi dipanggil. Apabila tidak ada objek semasa, ini merujuk kepada objek global. Dalam penyemak imbas web, ia diwakili oleh tetingkap. Apabila memanggil fungsi, ini mengekalkan objek global; tetapi apabila memanggil pembina objek atau mana -mana kaedahnya, ini merujuk kepada contoh objek. Anda boleh mengubah konteks ini menggunakan kaedah seperti panggilan (), memohon (), dan mengikat (). Kaedah ini memanggil fungsi menggunakan nilai dan parameter yang diberikan. JavaScript adalah bahasa pengaturcaraan yang sangat baik. Beberapa tahun yang lalu, ayat ini

JQuery adalah rangka kerja JavaScript yang hebat. Walau bagaimanapun, seperti mana -mana perpustakaan, kadang -kadang perlu untuk mendapatkan di bawah tudung untuk mengetahui apa yang sedang berlaku. Mungkin kerana anda mengesan bug atau hanya ingin tahu tentang bagaimana jQuery mencapai UI tertentu

Siaran ini menyusun helaian cheat berguna, panduan rujukan, resipi cepat, dan coretan kod untuk perkembangan aplikasi Android, BlackBerry, dan iPhone. Tiada pemaju harus tanpa mereka! Panduan Rujukan Gesture Touch (PDF) Sumber yang berharga untuk desig


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

PhpStorm versi Mac
Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod
