


Kenapa acara Onchange dalam React Fire beberapa kali apabila input?
Acara Onchange mencetuskan beberapa kali dalam React: Perbincangan mendalam
Dalam perkembangan React, peristiwa onChange
kotak input kadang -kadang secara tidak sengaja dicetuskan beberapa kali. Artikel ini akan menganalisis masalah ini secara mendalam dan memberikan penyelesaian.
Penerangan Masalah
Komponen reaksi mudah yang menguruskan keadaan menggunakan cangkuk useState
dan mengemas kini keadaan dan cetakan dalam acara onChange
dalam kotak input. Walau bagaimanapun, apabila memasuki watak, konsol mencetak dua kali. Fenomena ini amat jelas apabila menggunakan keadaan jenis objek, tetapi tidak berlaku apabila menggunakan keadaan jenis primitif.
Contoh kod coretan (kod masalah):
Import React, {Usestate} dari "React"; Eksport Fungsi Default Child () { const [state, setState] = useState ({}); const onChange = (event) => { setState ({... state, value: event.target.value}); console.log ("onchange dicetuskan", negeri); }; Kembali ( <div> <input type="text" onchange="{onChange}"> </div> ); }
Analisis masalah
Akar masalah ini terletak pada mod ketat React. Dalam persekitaran pembangunan, mod yang ketat melakukan dua penulisan untuk membantu pemaju menemui masalah yang berpotensi, seperti kesan sampingan yang tidak perlu.
Apabila keadaan adalah jenis objek, setState
mengemas kini rujukan kepada objek, bukan nilai itu sendiri. Rendering berganda mod ketat menyebabkan peristiwa onChange
dipanggil dua kali, setiap kali rujukan objek yang sama dikemas kini. Keadaan jenis asal (seperti rentetan, nombor) secara langsung mengemas kini nilai, jadi masalah ini tidak akan berlaku.
punca akar
- Kemas kini rujukan jenis objek keadaan: Apabila menggunakan objek sebagai keadaan,
setState
akan membuat objek baru, tetapiconsole.log
di dalam fungsionChange
masih mencetak keadaan lama kerana mekanisme kemas kini asynchronous React. Status dikemas kini dengan nilai baru hanya semasa rendering kedua. - Rendering dua mod yang ketat: Mod yang ketat dalam persekitaran pembangunan mencetuskan rendering dua, memburukkan masalah ini.
Penyelesaian
Elakkan menggunakan keadaan jenis objek, atau mengoptimumkan kaedah panggilan setState
:
Kaedah 1: Gunakan keadaan jenis asal
Tukar keadaan ke jenis asal, seperti rentetan:
Import React, {Usestate} dari "React"; Eksport Fungsi Default Child () { const [inputValue, setInputValue] = useState (""); const onChange = (event) => { setInputValue (event.target.value); console.log ("onchange dicetuskan", inputValue); }; Kembali ( <div> <input type="text" value="{inputValue}" onchange="{onChange}"> </div> ); }
Kaedah 2: Gunakan kemas kini fungsional
Gunakan kemas kini fungsional setState
untuk memastikan setiap kemas kini berdasarkan status terkini:
Import React, {Usestate} dari "React"; Eksport Fungsi Default Child () { const [state, setState] = useState ({}); const onChange = (event) => { setState ((prevstate) => ({... prevstate, nilai: event.target.value})); console.log ("onchange dicetuskan", negeri); }; Kembali ( <div> <input type="text" onchange="{onChange}"> </div> ); }
Melalui kaedah di atas, masalah peristiwa onChange
yang mencetuskan beberapa kali dalam React dapat diselesaikan dengan berkesan. Ingat, mod ketat dilumpuhkan dalam persekitaran pengeluaran, jadi masalah ini biasanya hanya berlaku dalam persekitaran pembangunan.
Atas ialah kandungan terperinci Kenapa acara Onchange dalam React Fire beberapa kali apabila input?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Adakah anda ingin tahu cara memaparkan kategori kanak -kanak di halaman arkib kategori induk? Apabila anda menyesuaikan halaman arkib klasifikasi, anda mungkin perlu melakukan ini untuk menjadikannya lebih berguna kepada pelawat anda. Dalam artikel ini, kami akan menunjukkan kepada anda bagaimana untuk memaparkan kategori kanak -kanak dengan mudah di halaman arkib kategori induk. Mengapa subkategori muncul di halaman arkib kategori induk? Dengan memaparkan semua kategori kanak -kanak di halaman arkib kategori induk, anda boleh menjadikannya kurang generik dan lebih berguna kepada pelawat. Sebagai contoh, jika anda menjalankan blog WordPress mengenai buku dan mempunyai taksonomi yang disebut "tema", anda boleh menambah sub-taksonomi seperti "novel", "bukan fiksyen" supaya pembaca anda dapat

Bagaimanakah penyelesaian caching Redis menyedari keperluan senarai kedudukan produk? Semasa proses pembangunan, kita sering perlu menangani keperluan kedudukan, seperti memaparkan ...

Memahami rawak kebergantungan bulat dalam permulaan projek musim bunga. Semasa membangunkan projek musim bunga, anda mungkin menghadapi rawak yang disebabkan oleh kebergantungan bulat pada permulaan projek ...

Faktor kenaikan harga mata wang maya termasuk: 1. Peningkatan permintaan pasaran, 2. Menurunkan bekalan, 3. Berita positif yang dirangsang, 4. Sentimen pasaran optimis, 5. Persekitaran makroekonomi; Faktor penurunan termasuk: 1. Mengurangkan permintaan pasaran, 2. Peningkatan bekalan, 3.

Kenapa nilai pulangan kosong apabila menggunakan redistemplate untuk pertanyaan batch? Apabila menggunakan Redistemplate untuk operasi pertanyaan batch, anda mungkin menghadapi hasil yang dikembalikan ...

Penyelesaian pengoptimuman untuk tugas masa springboot dalam persekitaran pelbagai nod sedang membangunkan musim bunga ...

Perbincangan mengenai sebab -sebab mengapa JavaScript tidak dapat memperoleh maklumat perkakasan komputer pengguna dalam pengaturcaraan harian, banyak pemaju akan ingin tahu tentang mengapa JavaScript tidak dapat diperoleh secara langsung ...

Mengenai sebab mengapa redistemplate.OpsForList (). LeftPop () tidak menyokong nombor lulus. Apabila menggunakan Redis, banyak pemaju akan menghadapi masalah: mengapa redistempl ...
