Bagaimanakah cara saya menghantar parameter kepada setTimeout dalam JavaScript dan mengelakkan pelaksanaan segera?

DDD
Lepaskan: 2024-10-31 21:41:29
asal
156 orang telah melayarinya

How do I pass parameters to setTimeout in JavaScript and avoid immediate execution?

Pelaksanaan Skrip Tertunda dalam JavaScript: Meneroka setTimeout dan Fungsi Tanpa Nama

Pembangun sering menghadapi keperluan untuk menangguhkan pelaksanaan skrip dalam JavaScript. Untuk mencapai matlamat ini, setTimeout berfungsi sebagai alat yang berharga. Walau bagaimanapun, perlu diingat bahawa menghantar parameter dengan setTimeout memerlukan pengendalian melalui fungsi tanpa nama.

Dalam contoh yang diberikan, panggilan setTimeout dibuat untuk memaparkan amaran selepas 2000 milisaat. Walau bagaimanapun, kod tersebut tersilap melepasi fungsi amaran dengan parameter yang disertakan dalam kurungan ("alert("Hello " a)"), yang membawa kepada amaran dipaparkan serta-merta.

Untuk menangani perkara ini, kod boleh diubah suai dalam dua cara:

  1. Menggunakan Nama Fungsi: Takrifkan fungsi dengan kod yang akan dilaksanakan kemudian dan hantar nama fungsi sebagai argumen kepada setTimeout. Ini membolehkan parameter lulus dalam definisi fungsi.
  2. Menggunakan Fungsi Tanpa Nama: Cipta fungsi tanpa nama yang merangkum kod yang akan dilaksanakan kemudian dan hantar fungsi ini kepada setTimeout. Pendekatan ini amat berguna apabila parameter perlu diluluskan.

Dalam mana-mana kes, ingat untuk menggunakan fungsi panggil balik apabila menghantar parameter untuk mengekalkan nilai asal pembolehubah kerana ia mungkin berubah sebelum pelaksanaan tertunda berlaku.

Atas ialah kandungan terperinci Bagaimanakah cara saya menghantar parameter kepada setTimeout dalam JavaScript dan mengelakkan pelaksanaan segera?. 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
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!