Apabila pembangun mula-mula menemui setTimeout dalam JavaScript, ia selalunya kelihatan seperti alat yang mudah untuk menangguhkan pelaksanaan fungsi. Walau bagaimanapun, memahami cara setTimeout berinteraksi dengan masa jalan JavaScript dan gelung acara boleh mendedahkan beberapa tingkah laku yang tidak dijangka, terutamanya dalam keadaan tertentu. Dan ia bukan sahaja setTimeout; kerumitan serupa timbul dengan setInterval dan fungsi tak segerak yang lain juga.
Gelung Acara: Gambaran Keseluruhan Ringkas
JavaScript adalah satu-benang, bermakna ia hanya boleh melaksanakan satu keping kod pada satu masa. Walaupun begitu, gelung acara membenarkan JavaScript untuk melaksanakan operasi tanpa sekatan. Ia mencapai ini dengan memunggah tugas seperti pemasa, permintaan rangkaian atau operasi I/O ke penyemak imbas atau API Node.js. Setelah tugasan ini selesai, fungsi panggil baliknya akan digilir semula ke gelung acara untuk dilaksanakan.
Cara setTimeout berfungsi
Apabila anda memanggil setTimeout, anda meminta enjin JavaScript untuk melaksanakan fungsi selepas tempoh tertentu. Ini dilakukan dengan menambahkan fungsi panggil balik pada baris gilir gelung acara. Walau bagaimanapun, kelewatan yang dinyatakan ialah masa minimum enjin perlu menunggu sebelum menambah panggilan balik pada baris gilir, bukan masa pelaksanaan yang dijamin. Begini cara ia berfungsi secara terperinci:
Panggilan Permulaan: Apabila setTimeout digunakan dengan fungsi panggil balik dan kelewatan, enjin JavaScript mendaftarkannya dalam persekitaran API Web yang disediakan oleh penyemak imbas atau Node.js.
Pemasa: API Web memulakan pemasa untuk kelewatan yang ditentukan. Dalam tempoh ini, timbunan panggilan utama terus melaksanakan sebarang kod segerak yang mengikuti panggilan setTimeout.
Baris Gilir Panggilan Balik: Setelah pemasa tamat tempoh, API Web tidak segera melaksanakan panggilan balik. Sebaliknya, ia mengalihkan fungsi panggil balik ke baris gilir acara.
Gelung Peristiwa: Gelung acara, yang memantau tindanan panggilan dan baris gilir acara secara berterusan, mula dimainkan. Jika tindanan panggilan kosong, bermakna tiada tugas yang sedang dilaksanakan, gelung acara mengambil fungsi pertama daripada baris gilir acara dan menolaknya ke tindanan panggilan untuk pelaksanaan.
Pelaksanaan: Fungsi panggil balik akhirnya dilaksanakan apabila ia mencapai bahagian atas tindanan panggilan.
Perlu ambil perhatian bahawa jika timbunan panggilan sibuk dengan tugas lain apabila pemasa tamat tempoh, mungkin terdapat kelewatan tambahan sebelum fungsi panggil balik dilaksanakan. Ini kerana gelung peristiwa mesti menunggu sehingga tindanan panggilan jelas sebelum ia boleh memproses fungsi panggil balik daripada baris gilir acara.
Isu Penyekatan
Salah faham biasa ialah menganggap setTimeout akan sentiasa melaksanakan panggilan balik selepas kelewatan tepat ditentukan. Jika gelung peristiwa disekat oleh kod segerak, seperti gelung tak terhingga atau pengiraan jangka panjang, panggilan balik tidak akan dilaksanakan sehingga gelung acara bebas.
Pertimbangkan senario berikut:
console.log('Program started at: ' + new Date().toLocaleTimeString()); const programStartTime = Date.now(); function blockExecutionForThirtySeconds() { while (true) { const currentTime = Date.now(); if (currentTime - programStartTime > 30000) { console.log('Blocking execution completed after 30 seconds...'); return true; } } } console.log('Setting setTimeout for 1 second.'); setTimeout(() => { console.log('setTimeout executed after 30 seconds instead of 1 second: ' + new Date().toLocaleTimeString()); }, 1000); blockExecutionForThirtySeconds();
Dalam contoh ini, fungsi blockExecutionForThirtySeconds menyekat gelung peristiwa dengan gelung tak terhingga yang berjalan selama 30 saat. Walaupun setTimeout ditetapkan untuk dilaksanakan selepas 1 saat, ia hanya akan dijalankan selepas blockExecutionForThirtySeconds selesai, iaitu selepas 30 saat.
Implikasi Dunia Sebenar
Memahami tingkah laku ini adalah penting untuk pembangun, terutamanya apabila menulis kod yang melibatkan tamat masa, selang waktu atau pemprosesan tak segerak. Salah faham cara setTimeout berfungsi boleh membawa kepada isu prestasi dan pepijat yang sukar dikesan. Jika sekeping kod melakukan pengiraan berat atau tugasan yang berjalan lama dan menyekat gelung acara, semua panggilan balik setTimeout, resolusi janji dan operasi tak segerak lain akan ditangguhkan sehingga gelung acara bebas.
Kesimpulan
setTimeout ialah alat yang berkuasa dalam JavaScript untuk menangguhkan pelaksanaan kod, tetapi penting untuk memahami nuansanya. Kelewatan yang dinyatakan ialah masa minimum untuk menunggu sebelum fungsi boleh dibariskan untuk pelaksanaan. Masa pelaksanaan sebenar bergantung pada keadaan gelung acara. Menguasai operasi tak segerak dan pengurusan gelung acara adalah kunci untuk menulis aplikasi JavaScript yang cekap dan responsif.
Atas ialah kandungan terperinci SetTimeout Tidak Sama seperti yang Anda Fikirkan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Penjelasan terperinci mengenai kaedah penggantian rentetan javascript dan Soalan Lazim Artikel ini akan meneroka dua cara untuk menggantikan watak rentetan dalam JavaScript: Kod JavaScript dalaman dan HTML dalaman untuk laman web. Ganti rentetan di dalam kod JavaScript Cara yang paling langsung ialah menggunakan kaedah pengganti (): str = str.replace ("cari", "ganti"); Kaedah ini hanya menggantikan perlawanan pertama. Untuk menggantikan semua perlawanan, gunakan ungkapan biasa dan tambahkan bendera global g: str = str.replace (/fi

Tutorial ini menunjukkan kepada anda bagaimana untuk mengintegrasikan API carian Google tersuai ke dalam blog atau laman web anda, menawarkan pengalaman carian yang lebih halus daripada fungsi carian tema WordPress standard. Ia menghairankan mudah! Anda akan dapat menyekat carian ke y

Siri artikel ini ditulis semula pada pertengahan 2017 dengan maklumat terkini dan contoh segar. Dalam contoh JSON ini, kita akan melihat bagaimana kita dapat menyimpan nilai mudah dalam fail menggunakan format JSON. Menggunakan notasi pasangan nilai utama, kami boleh menyimpan apa-apa jenis

Tingkatkan Penyampaian Kod Anda: 10 Penyeret Sintaks untuk Pemaju Coretan kod perkongsian di laman web atau blog anda adalah amalan biasa bagi pemaju. Memilih penyapu sintaks yang betul dapat meningkatkan daya tarikan dan daya tarikan visual dengan ketara. T

Jadi di sini anda, bersedia untuk mempelajari semua perkara ini yang dipanggil Ajax. Tetapi, apa sebenarnya? Istilah Ajax merujuk kepada kumpulan teknologi longgar yang digunakan untuk membuat kandungan web yang dinamik dan interaktif. Istilah Ajax, yang asalnya dicipta oleh Jesse J

Leverage JQuery untuk Layouts Laman Web yang mudah: 8 Plugin Essential JQuery memudahkan susun atur laman web dengan ketara. Artikel ini menyoroti lapan plugin jQuery yang kuat yang menyelaraskan proses, terutamanya berguna untuk penciptaan laman web manual

Artikel ini membentangkan pemilihan lebih daripada 10 tutorial mengenai rangka kerja javascript dan jquery model-view-controller (MVC), sesuai untuk meningkatkan kemahiran pembangunan web anda pada tahun baru. Tutorial ini merangkumi pelbagai topik, dari Foundatio

Mata teras Ini dalam JavaScript biasanya merujuk kepada objek yang "memiliki" kaedah, tetapi ia bergantung kepada bagaimana fungsi dipanggil. Apabila tidak ada objek semasa, ini merujuk kepada objek global. Dalam penyemak imbas web, ia diwakili oleh tetingkap. Apabila memanggil fungsi, ini mengekalkan objek global; tetapi apabila memanggil pembina objek atau mana -mana kaedahnya, ini merujuk kepada contoh objek. Anda boleh mengubah konteks ini menggunakan kaedah seperti panggilan (), memohon (), dan mengikat (). Kaedah ini memanggil fungsi menggunakan nilai dan parameter yang diberikan. JavaScript adalah bahasa pengaturcaraan yang sangat baik. Beberapa tahun yang lalu, ayat ini


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

PhpStorm versi Mac
Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Dreamweaver Mac版
Alat pembangunan web visual

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.
