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!