Bilakah anda harus menggunakan ciri pemuatan malas React?
P粉976737101
2023-08-24 23:11:02
<p>Saya mempunyai aplikasi yang agak besar dan saiz berkas kini kira-kira 2MB (kira-kira 3 ketul). Untuk menambah baik masa muat, saya memutuskan untuk mula menggunakan React Lazy yang agak baharu. </p>
<p>Ini ialah contoh pemuatan malas: </p>
<pre class="brush:php;toolbar:false;">const Wizard = React.lazy(() => import('./components/wizards/Wizard'));</pre>
<p>Saya faham idea umum konsep itu, tetapi saya masih menghadapi kesukaran untuk memahami kelemahannya selain kadang-kadang perlu menunggu seketika untuk ketulan dimuatkan. </p>
<p>Berdasarkan apa yang saya baca, saya tidak mempunyai sebab untuk menggunakan import biasa. </p>
<p><strong>Soalan saya ialah: patutkah saya menggunakan pemuatan malas pada setiap import komponen dalam aplikasi saya? kenapa? kenapa tidak? </strong></p>
<p>Saya ingin mendengar pendapat anda. </p>
Saya belum mula menggunakannya lagi. Tetapi saya fikir pendekatan yang paling optimistik ialah melakukan import tetap bagi semua komponen yang anda perlukan di halaman utama. Mana-mana laluan lain yang bukan halaman utama harus menggunakan pemuatan malas. Ini adalah pemikiran umum yang saya miliki.
Tidak, tidak diperlukan untuk setiap komponen. Ia hanya masuk akal untuk menggunakannya dalam setiap susun atur atau halaman. Tempat yang baik untuk bermula ialah penghalaan. Kebanyakan orang di web terbiasa dengan peralihan halaman yang mengambil masa tertentu untuk dimuatkan. Anda juga cenderung untuk memaparkan semula keseluruhan halaman sekaligus, jadi pengguna anda kurang berkemungkinan berinteraksi dengan elemen lain pada halaman pada masa yang sama.
Sebagai contoh, anda sedang mencipta aplikasi pengagregatan berita. Permohonan anda terdiri daripada dua halaman seperti
NewsList
和NewsItemPage
. Setiap halaman mengandungi beberapa komponen yang berbeza. Dalam contoh ini, masuk akal untuk menggunakan komponen memuatkan malas untuk setiap halaman lain. Ia kemudiannya akan memuatkan komponen yang diperlukannya.Apl ini mempunyai satu lagi
Header
和Footer
. Mereka harus dimuatkan dengan cara biasa. Kerana ia digunakan pada setiap halaman dan memuatkan secara tidak segerak tidak masuk akal.