Promise.all, kaedah yang berkuasa dalam JavaScript, digunakan untuk mengendalikan pelbagai Janji. Walaupun ia memudahkan penyelarasan, pengendalian ralat boleh menjadi rumit. Artikel ini membincangkan potensi cabaran dan menyediakan penyelesaian untuk mengurus ralat dengan berkesan.
The Promise.all Enigma
Promise.all, seperti namanya, bertujuan untuk komprehensif penyelesaian dengan menunggu semua Janji dalam tatasusunan selesai atau sehingga seseorang menghadapi ralat. Jika Janji gagal, Promise.all serta-merta menolak, mengabaikan Janji yang masih belum diselesaikan. Tingkah laku ini boleh mengehadkan, terutamanya apabila matlamatnya adalah untuk mendapatkan data daripada semua Janji, malah yang mengalami ralat.
Pengendalian Ralat dengan Janji Tidak Penyelesaian
A pendekatan biasa adalah untuk menangkap ralat dalam setiap Janji, mengembalikan ralat sebagai nilai biasa. Ini membolehkan rantai Promise.all menyelesaikan dengan tatasusunan yang mengandungi kedua-dua nilai yang diselesaikan dan objek ralat. Walau bagaimanapun, pendekatan ini menganggap bahawa kod seterusnya boleh mengendalikan objek ralat sebagai nilai kejayaan, yang mungkin tidak selalu berlaku.
Promise.when: Pendekatan Alternatif
Sesetengah perpustakaan menawarkan varian yang dipanggil Promise.when, yang berkelakuan berbeza daripada Promise.all. Daripada menolak pada ralat pertama, Promise.when menunggu semua Promise sama ada menyelesaikan atau menolak, mengembalikan tatasusunan yang mencerminkan hasil setiap Promise. Ini boleh berguna apabila matlamatnya adalah untuk mendapatkan hasil daripada semua Janji, tanpa mengira ralat.
Pelaksanaan dalam Kod Sebenar
Coretan kod berikut menunjukkan cara mengendalikan ralat dalam Promise.all sambil membenarkan Janji yang tidak dapat diselesaikan:
<code class="javascript">Promise.all(state.routes.map(function(route) { return route.handler.promiseHandler().catch(function(err) { return err; }); })) .then(function(arrayOfValuesOrErrors) { // Handle array containing both values and error objects }) .catch(function(err) { // Handle unexpected errors });</code>
Dalam kod ini, setiap Promise dalam tatasusunan mengendalikan ralat secara dalaman, mengembalikan ralat sebagai nilai. Promise.all menyelesaikan dengan tatasusunan yang mengandungi kedua-dua nilai diselesaikan dan objek ralat. Kod berikutnya kemudiannya boleh memproses tatasusunan ini untuk mengendalikan hasil yang berjaya dan ralat secara berasingan.
Kesimpulan
Dengan memahami batasan Promise.all dan menggunakan pendekatan alternatif seperti Promise. apabila atau pengendalian ralat tersuai dalam Promises, pembangun boleh mengurus ralat dengan berkesan dan mendapatkan data daripada semua Promises, tanpa mengira ralat yang dihadapi.
Atas ialah kandungan terperinci Bagaimana Mengendalikan Ralat dengan Anggun dengan Promise.all dalam JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!