Rumah > hujung hadapan web > tutorial js > Bagaimanakah Promise.all() Boleh Mengendalikan Berbilang Tugas Asynchronous Dengan Cekap Sebelum Meneruskan Operasi Seterusnya?

Bagaimanakah Promise.all() Boleh Mengendalikan Berbilang Tugas Asynchronous Dengan Cekap Sebelum Meneruskan Operasi Seterusnya?

Patricia Arquette
Lepaskan: 2024-12-15 19:19:15
asal
846 orang telah melayarinya

How Can Promise.all() Efficiently Handle Multiple Asynchronous Tasks Before Proceeding to Subsequent Operations?

Bekerja dengan Pelbagai Janji Secara Asynchronous

Artikel ini bertujuan untuk menangani cabaran melaksanakan pelbagai tugas tak segerak dalam gelung dan keperluan untuk memastikan penyelesaiannya sebelum meneruskan tugasan seterusnya.

Masalah: Mengendalikan Tugasan Asynchronous dalam Gelung

Bayangkan senario di mana gelung berulang pada set tugasan, setiap satunya dilaksanakan secara tak segerak. Mengikuti gelung, gelung lain bergantung pada penyiapan tugas gelung pertama. Bagaimanakah kita boleh mencapai penyelarasan ini dengan cekap?

Janji dan Janji.all()

Janji menyediakan penyelesaian yang elegan untuk masalah ini. Dengan mengembalikan janji daripada doSomeAsyncStuff(), kami boleh mengurus operasi tak segerak.

Promise.all() ialah kaedah berkuasa yang menerima pelbagai janji dan mengembalikan satu janji. Janji tunggal ini diselesaikan hanya apabila semua janji input diselesaikan atau mana-mana daripadanya ditolak.

Pelaksanaan

Untuk mencapai matlamat kami, kami boleh memanfaatkan Promise.all() seperti berikut:

const promises = [];

for (let i = 0; i < 5; i++) {
  promises.push(doSomeAsyncStuff());
}

Promise.all(promises)
  .then(() => {
    // Execute tasks that require all async tasks to finish
  })
  .catch((e) => {
    // Handle errors
  });
Salin selepas log masuk

Dalam pelaksanaan ini, kami mengumpulkan semua janji dalam tatasusunan dan menyerahkannya kepada Promise.all(). Selepas penyelesaiannya (atau penolakan), kami meneruskan tugas gelung kedua.

Pertimbangan Tambahan

  • Untuk menambah kejelasan, gunakan const atau let dan bukannya var.
  • Pertimbangkan untuk mengendalikan ralat menggunakan kaedah tangkapan.
  • Untuk pemahaman lanjut, rujuk dokumentasi MDN tentang janji dan buku saya "JavaScript: The New Toys" (pautan disediakan dalam profil saya).

Contoh

Contoh berikut menunjukkan penggunaan Promise.all() untuk menunggu untuk berbilang tugas tak segerak untuk diselesaikan:

function doSomethingAsync(value) {
  return new Promise((resolve) => {
    setTimeout(() => {
      console.log("Resolving " + value);
      resolve(value);
    }, Math.floor(Math.random() * 1000));
  });
}

function test() {
  const promises = [];

  for (let i = 0; i < 5; i++) {
    promises.push(doSomethingAsync(i));
  }

  Promise.all(promises)
    .then((results) => {
      console.log("All done", results);
    })
    .catch((e) => {
      // Handle errors
    });
}

test();
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimanakah Promise.all() Boleh Mengendalikan Berbilang Tugas Asynchronous Dengan Cekap Sebelum Meneruskan Operasi Seterusnya?. 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