Menguruskan Keputusan Perantaraan dalam Rantai Janji
Masalah:
Apabila mencipta rantai janji, ia boleh mencabar untuk mengakses hasil janji perantaraan dalam panggilan balik terakhir. Dalam contoh berikut, bagaimanakah kita boleh mengakses hasil promiseA dalam panggilan balik untuk promiseB?
function getExample() { return promiseA(…).then(function(resultA) { // Processing return promiseB(…); }).then(function(resultB) { // How can we access resultA here? }); }
Penyelesaian: Memutuskan Rantaian
Untuk mengakses hasil perantaraan dalam rantai janji, sebaiknya pecahkan rantai itu kepada komponen yang berasingan. Ini membolehkan anda melampirkan berbilang panggilan balik pada janji yang sama, mengakses nilai yang diselesaikan apabila diperlukan. Berikut ialah versi kod yang dipertingkatkan:
function getExample() { var a = promiseA(…); var b = a.then(function(resultA) { // Processing return promiseB(…); }); return Promise.all([a, b]).then(function([resultA, resultB]) { // Processing using both resultA and resultB return …; }); }
Pendekatan ini menggunakan kaedah Promise.all() untuk mencipta tatasusunan semua janji dalam rantaian. Kami kemudian merantai panggilan balik then() yang lain kepada hasil Promise.all(), menghantar fungsi yang menerima tatasusunan nilai yang diselesaikan. Ini membolehkan kami mengakses kedua-dua resultA dan resultB dengan mudah dalam panggilan balik terakhir.
Penyelesaian Ganti:
Dalam ES5, anda boleh menggunakan kaedah .spread() untuk mencapai kefungsian serupa:
… return Promise.all([a, b]).then(.spread(function(resultA, resultB) { … });
Bluebird menyediakan kaedah join() khusus yang memudahkan proses ini selanjutnya:
… return Promise.join(a, b, function(resultA, resultB) { … });
Dengan memutuskan rantaian dan menggunakan penggabung janji yang sesuai, anda boleh mengakses dan memanipulasi hasil janji perantaraan secara elegan, memastikan struktur kod yang jelas dan cekap.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengakses Keputusan Janji Perantaraan dalam Rantai Janji JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!