Bagaimana Mengendalikan Ralat dengan Anggun dengan Promise.all dalam JavaScript?

Barbara Streisand
Lepaskan: 2024-10-30 23:28:30
asal
864 orang telah melayarinya

How to Handle Errors Gracefully with Promise.all in JavaScript?

Mengendalikan Ralat Pengendalian dalam Promise.all

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>
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!