Apabila mengendalikan senario tak segerak, adalah penting untuk mengelakkan nod ranap daripada panggilan balik jahat. Dalam artikel ini, kami akan meneroka amalan terbaik untuk menggunakan janji Bluebird untuk menangani cabaran ini.
Pertimbangkan senario berikut:
function getPromise() { return new Promise((done, reject) => { setTimeout(() => { throw new Error("AJAJAJA"); }, 500); }); } ...
Dengan membuang pengecualian dalam setTimeout, kami memintas mekanisme pengendalian ralat Bluebird dan ranap program. Walau bagaimanapun, jika pengecualian berlaku sebelum setTimeout, Bluebird berjaya menangkapnya:
function getPromise() { return new Promise((done, reject) => { throw new Error("Oh no!"); setTimeout(() => { console.log("hihihihi"); }, 500); }); } ...
Ini menunjukkan bahawa Promises tidak memintas pengecualian daripada panggilan balik tak segerak. Sebaliknya, mereka mengendalikan ralat hanya dalam panggilan balik pembina mereka atau kemudian/tangkap panggil balik.
Untuk mengelakkan ranap nod, jangan sekali-kali membuang ralat dalam panggilan balik tak segerak tersuai. Sebaliknya, tolak janji sekeliling. Pertimbangkan pengubahsuaian berikut:
function getPromise() { return new Promise((done, reject) => { setTimeout(() => { done(); }, 500); }).then(() => { console.log("hihihihi"); throw new Error("Oh no!"); }); } ...
Dengan menggunakan kemudian untuk membalut operasi async, kami kini boleh menangani ralat dalam panggilan balik Bluebird.
Atas ialah kandungan terperinci Bagaimanakah Janji Bluebird Boleh Menyelesaikan Cabaran Pengendalian Pengecualian Asynchronous dalam Node.js?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!