Jadual Kandungan
Acara Onchange mencetuskan beberapa kali dalam React: Perbincangan mendalam
Penerangan Masalah
Analisis masalah
punca akar
Penyelesaian
Rumah hujung hadapan web tutorial js Kenapa acara Onchange dalam React Fire beberapa kali apabila input?

Kenapa acara Onchange dalam React Fire beberapa kali apabila input?

Apr 04, 2025 pm 07:12 PM
kenapa red

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>
  );
}
Salin selepas log masuk

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, tetapi console.log di dalam fungsi onChange 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>
  );
}
Salin selepas log masuk

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>
  );
}
Salin selepas log masuk

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!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Cara memaparkan kategori kanak -kanak di halaman arkib kategori induk Cara memaparkan kategori kanak -kanak di halaman arkib kategori induk Apr 19, 2025 pm 11:54 PM

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

Bagaimana menggunakan penyelesaian cache Redis untuk merealisasikan keperluan senarai kedudukan produk dengan cekap? Bagaimana menggunakan penyelesaian cache Redis untuk merealisasikan keperluan senarai kedudukan produk dengan cekap? Apr 19, 2025 pm 11:36 PM

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

Kenapa projek musim bunga menyebabkan masalah rawak akibat kebergantungan bulat apabila bermula? Kenapa projek musim bunga menyebabkan masalah rawak akibat kebergantungan bulat apabila bermula? Apr 19, 2025 pm 11:21 PM

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 ...

Mengapa kenaikan atau kejatuhan harga mata wang maya? Mengapa kenaikan atau kejatuhan harga mata wang maya? Mengapa kenaikan atau kejatuhan harga mata wang maya? Mengapa kenaikan atau kejatuhan harga mata wang maya? Apr 21, 2025 am 08:57 AM

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? Kenapa nilai pulangan kosong apabila menggunakan redistemplate untuk pertanyaan batch? Apr 19, 2025 pm 10:15 PM

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

Dalam persekitaran multi-nod, bagaimana untuk memastikan bahawa tugas masa @scheduled Spring Boot hanya dilaksanakan pada satu nod? Dalam persekitaran multi-nod, bagaimana untuk memastikan bahawa tugas masa @scheduled Spring Boot hanya dilaksanakan pada satu nod? Apr 19, 2025 pm 10:57 PM

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

Kenapa JavaScript secara langsung tidak dapat mendapatkan maklumat perkakasan secara langsung di komputer pengguna? Kenapa JavaScript secara langsung tidak dapat mendapatkan maklumat perkakasan secara langsung di komputer pengguna? Apr 19, 2025 pm 08:15 PM

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 ...

Kenapa kaedah redistemplate.opsForlist (). LeftPop () Kaedah tidak menyokong lulus parameter untuk muncul pelbagai nilai sekaligus? Kenapa kaedah redistemplate.opsForlist (). LeftPop () Kaedah tidak menyokong lulus parameter untuk muncul pelbagai nilai sekaligus? Apr 19, 2025 pm 10:27 PM

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

See all articles