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

Mengapa Fungsi `onClick` React Saya Menyala Semasa Perenderan?

Barbara Streisand
Barbara Streisandasal
2024-11-16 13:55:03314semak imbas

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)}>

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)}>

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!

Kenyataan:
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