State set fungsional: Memahami Tujuan dan Faedahnya
Dalam React, mengurus keadaan komponen adalah penting. Salah satu kaedah utama untuk mengubah suai keadaan ialah setState(). Walaupun terdapat beberapa pendekatan untuk menggunakan setState(), perbezaan wujud antara dua sintaks biasa:
this.setState({ pictures: pics });
dan
this.setState(prevState => ({ pictures: prevState.pictures.concat(pics) }));
Perbezaan utama terletak pada cara sintaks ini mengendalikan kemas kini keadaan apabila berbilang setState() panggilan berlaku dalam kitaran pemaparan yang sama.
Mengapa Functional setState Diutamakan
setState() melakukan kemas kini tak segerak, bermakna keadaan tidak diubah suai serta-merta. Selain itu, React boleh mengumpulkan berbilang setState() panggilan untuk meningkatkan prestasi. Ini bermakna dalam contoh pertama, jika setState() dipanggil berbilang kali dalam kitaran pemaparan yang sama, kemas kini keadaan mungkin hanya berlaku dengan nilai akhir.
SetState fungsional, sebaliknya, memastikan keadaan itu kemas kini adalah konsisten dan boleh diramal. Dalam sintaks kedua, fungsi pengemas kini menerima keadaan semasa sebagai hujah, membolehkan anda mengubah suai keadaan berdasarkan nilai sebelumnya. Ini menjamin bahawa keadaan dikemas kini dikira dengan betul, walaupun apabila berbilang setState() panggilan berlaku.
Contoh
Pertimbangkan senario berikut:
myFunction = () => { ... this.setState({ pictures: this.state.pictures.concat(pics1) }); this.setState({ pictures: this.state.pictures.concat(pics1) }); this.setState({ pictures: this.state.pictures.concat(pics1) }); ... };
Dalam kes ini, keadaan hanya akan dikemas kini sekali dengan nilai akhir pics1.
Faedah Tambahan Fungsi SetState
Untuk membuat kesimpulan, sementara kedua-dua sintaks boleh mengemas kini keadaan, setState berfungsi amat disyorkan disebabkan kelebihannya dalam memastikan kemas kini yang konsisten dan boleh diramal, terutamanya dalam senario yang melibatkan berbilang setState() panggilan dalam kitaran render. Ia menyediakan pendekatan yang lebih selamat dan fleksibel kepada pengurusan negeri, mempromosikan kebolehselenggaraan kod dan mengurangkan potensi isu.
Atas ialah kandungan terperinci Mengapa Functional setState Diutamakan untuk Kemas Kini Keadaan Konsisten dalam React?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!