Rumah > Artikel > hujung hadapan web > Bagaimana Mengendalikan Ralat Individu dalam Promise.all dan Mengakses Data Promise yang Tidak Terjejas?
Menangkap Ralat dalam Janji.semua
Masalah:
Apabila menggunakan Promise.all untuk mengendalikan pelbagai janji, menangkap ralat janji individu adalah mencabar kerana Promise.all mengembalikan ralat pertama yang ditemui dan mengabaikan yang lain. Akibatnya, data daripada janji yang tidak terjejas dalam tatasusunan menjadi tidak boleh diakses.
Penyelesaian:
Tingkah laku yang wujud pada Promise.all ialah mengembalikan tatasusunan nilai yang diselesaikan atau menolak dengan ralat tunggal apabila mana-mana janji ahli ditolak.
Walau bagaimanapun, anda boleh mengubah suai kod anda seperti berikut untuk mengendalikan ralat individu sambil masih menerima nilai daripada janji yang berjaya:
existingPromiseChain = existingPromiseChain.then(function() { var arrayOfPromises = state.routes.map(function(route) { return route.handler.promiseHandler() .then(function(data) { return data; }) .catch(function(err) { return { error: err }; }); }); return Promise.all(arrayOfPromises); }); existingPromiseChain = existingPromiseChain.then(function(arrayResolved) { // do stuff with my array of resolved promises (values or error objects), eventually ending with a res.send(); });
Penjelasan :
Dengan menangkap ralat secara individu dan mengembalikan objek ralat, anda membenarkan Promise.all menyelesaikan dengan tatasusunan yang mengandungi nilai yang diselesaikan dan objek ralat. Blok then() anda kemudiannya boleh mengendalikan tatasusunan bercampur ini dengan sewajarnya.
Atas ialah kandungan terperinci Bagaimana Mengendalikan Ralat Individu dalam Promise.all dan Mengakses Data Promise yang Tidak Terjejas?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!