Apabila menggunakan cangkuk useEffect dalam React 18 dengan StrictMode, anda mungkin perasan bahawa cangkuk dipanggil dua kali pada pelekap awal. Ini boleh menimbulkan kebimbangan, terutamanya jika anda melihat tingkah laku yang tidak dijangka dalam aplikasi anda.
Menurut dokumentasi React, ini adalah tingkah laku yang dimaksudkan yang diperkenalkan dalam React 18 untuk bersedia untuk masa hadapan penambahbaikan yang melibatkan pemeliharaan negeri dan kemas kini UI yang cekap. Dengan memasang semula komponen pada lekap, React menyasarkan untuk memastikan kod anda tahan terhadap kesan yang dipasang dan dinyahlekap beberapa kali.
Perlu ambil perhatian bahawa tingkah laku ini khusus ke mod pembangunan dengan StrictMode didayakan. Dalam mod pengeluaran, hanya satu panggilan dibuat.
Jika anda menghadapi masalah dengan tingkah laku ini, pertimbangkan pendekatan berikut:
1 . Kendalikan Pembersihan:
Pastikan useEffect anda mempunyai fungsi pembersihan untuk melaksanakan operasi yang diperlukan apabila komponen dinyahlekapkan. Ini menghalang isu seperti permintaan HTTP yang dibatalkan atau kebocoran memori.
2. Elakkan StrictMode dalam Pengeluaran:
Jika panggilan berganda menyebabkan isu penting, anda boleh melumpuhkan StrictMode dalam pengeluaran, kerana tingkah laku terhad kepada mod pembangunan.
3. Permintaan HTTP Cache:
Untuk mengelakkan permintaan HTTP pendua dalam pembangunan, gunakan perpustakaan yang menyimpan cache dan menyahgandakan permintaan.
Walaupun isu ini mungkin memerlukan perhatian, ia juga berfungsi sebagai peluang untuk menyemak semula penggunaan useEffect anda dan menggunakan yang terbaik amalan:
Ingat, panggilan double useEffect bertujuan untuk mendedahkan potensi pepijat dalam kod anda, membolehkan anda menulis aplikasi React yang mantap dan sedia pengeluaran.
Atas ialah kandungan terperinci Mengapakah UseEffect Hook Saya Berjalan Dua Kali dalam Mod Pembangunan React 18?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!