Rumah > hujung hadapan web > tutorial js > Mengapa Fungsi `onClick` React Saya Menyala Semasa Perenderan?

Mengapa Fungsi `onClick` React Saya Menyala Semasa Perenderan?

Barbara Streisand
Lepaskan: 2024-11-16 13:55:03
asal
313 orang telah melayarinya

Why Does My React `onClick` Function Fire During Rendering?

Memahami Pelaksanaan Pramatang Fungsi onClick React

Dalam React, adalah penting untuk memahami sebab fungsi onClick mungkin menyala semasa pemaparan. Fenomena ini boleh berlaku apabila menghantar nilai kepada komponen kanak-kanak.

Masalah:

Apabila memetakan senarai objek dan menggunakan fungsi map() untuk memaparkannya, butang yang dikaitkan dengan setiap objek menggunakan fungsi onClick secara pramatang semasa pemaparan.

Punca:

Kunci kepada isu ini terletak pada cara fungsi onClick diluluskan. Dalam kod yang disediakan, baris berikut bertanggungjawab untuk tingkah laku ini:

<button type="submit" onClick={this.props.removeTaskFunction(todo)}>
Salin selepas log masuk

Di sini, atribut onClick secara langsung menggunakan fungsi dengan menambah kurungan. Ini bermakna pengendali onClick dilaksanakan serta-merta, menyebabkan fungsi berjalan semasa pemaparan.

Penyelesaian:

Untuk mengelakkan pelaksanaan pramatang, anda harus menyerahkan fungsi itu sendiri kepada onClick dan bukannya menggunakannya. Ini boleh dicapai dengan menggunakan fungsi anak panah, yang diperkenalkan dalam ES6. Berikut ialah kod yang diperbetulkan:

<button type="submit" onClick={() => this.props.removeTaskFunction(todo)}>
Salin selepas log masuk

Penjelasan:

Dalam baris ini, kami menggunakan fungsi anak panah untuk mentakrifkan fungsi tanpa nama ringkas yang dihantar kepada onClick. Apabila butang diklik, fungsi anak panah kemudian akan menggunakan removeTaskFunction dengan objek todo. Pendekatan ini memastikan bahawa fungsi onClick hanya dicetuskan apabila butang diklik, bukan semasa pemaparan.

Atas ialah kandungan terperinci Mengapa Fungsi `onClick` React Saya Menyala Semasa Perenderan?. 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