Rumah > hujung hadapan web > tutorial js > Bagaimana untuk Mencapai Rantaian Asynchronous dalam Janji ES6 JavaScript untuk Gelung?

Bagaimana untuk Mencapai Rantaian Asynchronous dalam Janji ES6 JavaScript untuk Gelung?

Barbara Streisand
Lepaskan: 2024-11-22 11:52:12
asal
799 orang telah melayarinya

How to Achieve Asynchronous Chaining in a JavaScript ES6 Promise for Loop?

JavaScript ES6 Promise for Loop with Asynchronous Chaining

Dalam kod yang disediakan, percubaan dibuat untuk mencipta gelung for yang berulang 10 kali dan mencipta janji untuk setiap lelaran. Walau bagaimanapun, gelung dilaksanakan secara serentak, menghasilkan output yang tidak dapat diramalkan. Matlamatnya adalah untuk memastikan setiap janji berjalan hanya selepas janji sebelumnya diselesaikan.

Menjanjikan setTimeout

Untuk memudahkan penyelesaian, kami menentukan fungsi pembantu yang dipanggil kelewatan yang menjanjikan setTimeout fungsi:

const delay = ms => new Promise(resolve => setTimeout(resolve, ms));
Salin selepas log masuk

Mencipta Janji Asynchronous

Untuk memastikan pelaksanaan tak segerak, kami mencipta janji awal yang diselesaikan serta-merta. Setiap janji berikutnya dirantai dengan janji sebelumnya:

let p = Promise.resolve();
for (let i = 0; i < 10; i++) {
    p = p.then(() => delay(Math.random() * 1000))
         .then(() => console.log(i));
}
Salin selepas log masuk

Pendekatan ini memastikan setiap lelaran gelung mencipta janji yang diselesaikan selepas janji sebelumnya telah selesai. Pernyataan console.log(i) akan dilaksanakan dalam susunan yang betul, mencetak nilai dari 0 hingga 9.

Atas ialah kandungan terperinci Bagaimana untuk Mencapai Rantaian Asynchronous dalam Janji ES6 JavaScript untuk Gelung?. 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