Dalam JavaScript, menggunakan setInterval membenarkan pelaksanaan fungsi pada selang masa yang tetap. Walau bagaimanapun, kadangkala adalah perlu untuk melaraskan selang secara dinamik semasa pelaksanaan fungsi.
Dalam kod yang disediakan, pengguna bertujuan untuk memanipulasi rentetan dengan kesan rawak secara berterusan sehingga pembilang mencapai ambang. Untuk melengahkan kesan ini, pengguna ingin melaraskan selang setInterval secara dinamik berdasarkan nilai kaunter.
Malangnya, hanya mengubah suai parameter selang dalam fungsi setInterval itu sendiri tidak berkesan. Untuk menangani perkara ini, pendekatan yang berbeza diperlukan.
Penyelesaian 1: Menggunakan Fungsi Tanpa Nama
Penyelesaian pertama melibatkan penggunaan fungsi tanpa nama untuk menetapkan semula dan melaraskan setInterval secara dinamik :
var counter = 10; var myFunction = function() { clearInterval(interval); // Clear the current interval counter *= 10; // Update the interval value interval = setInterval(myFunction, counter); // Create a new interval with the updated value } var interval = setInterval(myFunction, counter); // Initialize the interval with the initial value
Dalam pendekatan ini, fungsi tanpa nama (myFunction) ditakrifkan dalam fungsi yang dipanggil oleh setInterval awal. Fungsi tanpa nama mengosongkan selang semasa, mengemas kini nilai selang berdasarkan pembilang, dan kemudian menetapkan selang baharu menggunakan nilai yang dikemas kini. Ini membolehkan pelarasan selang dinamik apabila pembilang berubah.
Penyelesaian 2: Menggunakan setTimeout
Seperti yang dicadangkan oleh A. Wolff, penggunaan setTimeout boleh menghapuskan keperluan untuk mengosongkan selang secara manual. Dengan setTimeout, selang baharu dijadualkan selepas setiap lelaran tanpa perlu mengosongkan yang sebelumnya:
var counter = 10; var myFunction = function() { counter *= 10; // Update the interval value setTimeout(myFunction, counter); // Schedule a new interval with the updated value } setTimeout(myFunction, counter); // Initialize the interval with the initial value
Dalam pendekatan ini, fungsi tanpa nama (myFunction) hanya perlu mengemas kini nilai selang dan setTimeout mengambil masa penjagaan menjadualkan lelaran seterusnya pada selang masa yang dikemas kini.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melaraskan Selang `setInterval` Secara Dinamik dalam JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!