Rumah >hujung hadapan web >tutorial js >Memahami React's useEffect dan Pendengar Acara: A Deep Dive
Pernahkah anda terfikir bagaimana komponen React boleh mengekalkan pendengar acara aktif tanpa mendaftar semula mereka pada setiap paparan? Mari kita bongkar misteri ini dengan memeriksa kes penggunaan biasa: menjejak koordinat tetikus.
Pertimbangkan komponen React ini yang menjejaki kedudukan tetikus:
import React from 'react'; function MouseCoords() { const [mousePosition, setMousePosition] = React.useState({ x: 0, y: 0, }); React.useEffect(() => { function handleMouseMove(event) { setMousePosition({ x: event.clientX, y: event.clientY, }); } window.addEventListener('mousemove', handleMouseMove); }, []); return ( <div className="wrapper"> <p> {mousePosition.x} / {mousePosition.y} </p> </div> ); } export default MouseCoords;
Inilah bahagian yang menarik: tatasusunan kebergantungan kosong ([]) bermaksud useEffect kami hanya berjalan sekali, namun komponen itu masih dikemas kini apabila kami menggerakkan tetikus kami. Bagaimana ini berfungsi? ?
Untuk memahami tingkah laku ini, kita perlu menyedari bahawa dua sistem berasingan sedang bermain:
Bayangkan menyediakan kamera keselamatan di rumah anda:
Mari kita periksa apa yang berlaku langkah demi langkah:
React.useEffect(() => { // Effect runs once on mount function handleMouseMove(event) { setMousePosition({ x: event.clientX, y: event.clientY, }); } window.addEventListener('mousemove', handleMouseMove); }, []); // Empty array = run once
Apabila tetikus bergerak:
Kami harus sentiasa membersihkan pendengar acara kami apabila komponen dinyahlekap. Inilah kod lengkapnya:
React.useEffect(() => { function handleMouseMove(event) { setMousePosition({ x: event.clientX, y: event.clientY, }); } window.addEventListener('mousemove', handleMouseMove); // Cleanup function return () => { window.removeEventListener('mousemove', handleMouseMove); }; }, []);
Berikut ialah versi yang lebih praktikal dengan ciri tambahan:
import React from 'react'; function MouseCoords() { const [mousePosition, setMousePosition] = React.useState({ x: 0, y: 0, }); React.useEffect(() => { function handleMouseMove(event) { setMousePosition({ x: event.clientX, y: event.clientY, }); } window.addEventListener('mousemove', handleMouseMove); }, []); return ( <div className="wrapper"> <p> {mousePosition.x} / {mousePosition.y} </p> </div> ); } export default MouseCoords;
Memahami hubungan antara useEffect React dan peristiwa penyemak imbas adalah penting untuk membina aplikasi React yang berprestasi. Dengan memanfaatkan sistem acara penyemak imbas dengan betul, kami boleh mencipta antara muka responsif tanpa pemaparan semula yang tidak perlu atau pendaftaran pendengar acara.
Ingat: pendengar acara adalah seperti kamera keselamatan setia kami - pasang sekali, dan biarkan ia melakukan tugasnya!
Adakah penjelasan ini membantu anda memahami useEffect dan pendengar acara dengan lebih baik? Tinggalkan komen di bawah dengan fikiran atau soalan anda!
Atas ialah kandungan terperinci Memahami React's useEffect dan Pendengar Acara: A Deep Dive. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!