JavaScript, sebagai bahasa satu utas, melaksanakan satu tugas pada satu masa. Walau bagaimanapun, ia mengendalikan operasi tak segerak dengan mudah, terima kasih kepada gelung acara. Gelung peristiwa ialah konsep asas yang menguatkan model konkurensi JavaScript, membolehkannya mengurus berbilang operasi dengan cekap tanpa menyekat utas utama. Dalam artikel ini, kami akan meneroka selok-belok gelung acara JavaScript, memahami cara ia berfungsi dan sebab ia penting untuk membangunkan aplikasi web responsif.
Gelung peristiwa ialah mekanisme yang digunakan oleh JavaScript untuk mengendalikan operasi tak segerak. Ia sentiasa menyemak timbunan panggilan dan baris gilir tugas, memastikan tugasan dilaksanakan dalam susunan yang betul. Matlamat utama gelung acara adalah untuk memastikan aplikasi responsif dengan mengurus pelaksanaan kod segerak dan tak segerak.
1. Tindanan Panggilan:
Timbunan panggilan ialah struktur data yang menjejaki panggilan fungsi dalam susunan Masuk Terakhir, Keluar Dahulu (LIFO). Apabila fungsi dipanggil, ia ditambahkan pada timbunan. Apabila pelaksanaan fungsi selesai, ia dialih keluar daripada tindanan.
2. API Web:
API Web disediakan oleh penyemak imbas (atau persekitaran Node.js) untuk mengendalikan operasi tak segerak seperti setTimeout, permintaan HTTP (XMLHttpRequest, Fetch API) dan acara DOM. API ini beroperasi di luar enjin JavaScript.
3. Barisan Panggil Balik (Barisan Tugas):
Baris gilir panggil balik ialah struktur data yang menyimpan panggilan balik operasi tak segerak. Panggilan balik ini dilaksanakan apabila tindanan panggilan kosong.
4. Gelung Acara:
Gelung acara sentiasa memantau timbunan panggilan dan baris gilir panggilan balik. Jika tindanan panggilan kosong, ia mengambil panggilan balik pertama daripada baris gilir dan menolaknya ke tindanan, membolehkan ia dilaksanakan.
Untuk memahami gelung acara, mari kita lihat contoh:
console.log('Start'); setTimeout(() => { console.log('Timeout'); }, 0); console.log('End');
1. Permulaan:
Fungsi console.log('Start') ditolak ke tindanan panggilan dan dilaksanakan, mencetak Mula ke konsol. Fungsi itu kemudian dialih keluar daripada timbunan.
2. Operasi Asynchronous:
Fungsi setTimeout dipanggil dengan panggilan balik dan kelewatan 0 milisaat. Fungsi setTimeout ditolak ke timbunan panggilan dan kemudian segera dikeluarkan selepas menetapkan pemasa. Panggilan balik dihantar ke API Web.
3. Sambungan:
Fungsi console.log('End') ditolak ke tindanan panggilan dan dilaksanakan, mencetak Tamat ke konsol. Fungsi itu kemudian dialih keluar daripada timbunan.
4. Pelaksanaan Panggilan Balik:
Selepas tindanan panggilan kosong, gelung acara menyemak baris gilir panggilan balik. Panggilan balik daripada setTimeout dialihkan ke baris gilir panggil balik dan kemudian ditolak ke tindanan panggilan, mencetak Timeout ke konsol.
Dalam JavaScript, tugasan dikategorikan kepada dua jenis: tugasan mikro dan tugasan makro. Memahami perbezaan antara mereka adalah penting untuk menulis kod tak segerak yang cekap.
1. Tugasan mikro:
Microtasks termasuk janji dan panggilan balik MutationObserver. Mereka mempunyai keutamaan yang lebih tinggi dan dilaksanakan sebelum tugasan makro. Selepas setiap tugasan makro, gelung acara menyemak baris gilir tugasan mikro dan melaksanakan semua tugasan mikro yang tersedia.
2.Macrotasks:
Macrotasks termasuk setTimeout, setInterval dan operasi I/O. Ia dilaksanakan mengikut susunan ia ditambahkan pada baris gilir panggil balik.
Pertimbangkan contoh berikut dengan janji:
console.log('Start'); setTimeout(() => { console.log('Timeout'); }, 0); Promise.resolve().then(() => { console.log('Promise'); }); console.log('End');
1. Permulaan:
console.log('Start') mencetak Mula.
setTimeout menjadualkan tugasan makro dengan kelewatan 0ms.
Promise.resolve().then() menjadualkan microtask.
console.log('End') mencetak Tamat.
2. Perlaksanaan Microtask:
Baris gilir microtask disemak dan panggilan balik promise dilaksanakan, mencetak Promise.
3. Pelaksanaan Tugasan Makro:
Baris gilir macrotask ditandakan dan panggilan balik setTimeout dilaksanakan, mencetak Timeout.
1. Elakkan Menyekat Benang Utama:
Lakukan pengiraan berat dalam pekerja web atau gunakan corak tak segerak untuk memastikan urutan utama responsif.
2. Gunakan Promises dan Async/Await:
Janji dan async/menunggu menjadikannya lebih mudah untuk mengendalikan operasi tak segerak dan meningkatkan kebolehbacaan kod.
3. Fahami Keutamaan Tugas:
Berhati-hati dengan perbezaan antara tugasan mikro dan tugasan makro untuk menulis kod yang lebih mudah diramal dan cekap.
Gelung acara JavaScript ialah mekanisme berkuasa yang membolehkan pengaturcaraan tak segerak dalam persekitaran satu benang. Dengan memahami cara gelung acara berfungsi, anda boleh menulis aplikasi web yang lebih cekap dan responsif. Ingat untuk memanfaatkan janji, async/tunggu dan pekerja web untuk mengurus tugas tak segerak dengan berkesan, memastikan pengalaman pengguna yang lancar dan lancar.
Atas ialah kandungan terperinci Gelung Acara JavaScript: Penyelaman Dalam. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!