Rumah > hujung hadapan web > tutorial js > Mengapakah useEffect Dijalankan pada Initial Render dalam React?

Mengapakah useEffect Dijalankan pada Initial Render dalam React?

Mary-Kate Olsen
Lepaskan: 2024-11-16 02:08:02
asal
523 orang telah melayarinya

Why Does useEffect Run on Initial Render in React?

Cara Menghalang useEffect Hook daripada Berjalan pada Initial Render

Dokumentasi React menyatakan bahawa kaedah kitaran hayat componentDidUpdate() tidak digunakan semasa render awal. Walau bagaimanapun, apabila menggunakan cangkuk useEffect untuk mensimulasikan componentDidUpdate(), ia kelihatan berjalan pada setiap pemaparan, termasuk yang pertama.

Penjelasan

Cangkuk useEffect dijalankan selepas setiap kitaran render, termasuk yang awal. Tidak seperti kaedah componentDidUpdate(), ia tidak mempunyai semakan terbina dalam untuk melangkau larian pertama.

Penyelesaian

Terdapat dua pendekatan untuk menangani perkara ini:

1. Menggunakan useRef

Kita boleh menggunakan cangkuk useRef untuk menjejaki sama ada ini kali pertama fungsi useEffect dipanggil.

const isFirstRender = useRef(true);

useEffect(() => {
  if (isFirstRender.current) {
    isFirstRender.current = false;
    return; // Skip the first render
  }

  console.log("Component did update");
}, [<dependencies>]);
Salin selepas log masuk

2. Menggunakan useLayoutEffect

useLayoutEffect adalah serupa dengan useEffect, tetapi ia berjalan dalam fasa yang sama seperti componentDidUpdate(), yang berlaku selepas operasi DOM.

useLayoutEffect(() => {
  console.log("Component did update");
}, [<dependencies>]);
Salin selepas log masuk

Atas ialah kandungan terperinci Mengapakah useEffect Dijalankan pada Initial Render dalam React?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan