var startIndex = 0;
var data = [1, 2, 3];
var timeout = 1000;
function functionToRun(i, length) {
alert(data[i]);
}
(function forWithDelay(i, length, fn, delay) {
setTimeout(function() {
fn(i, length);
i++;
if (i < length) {
forWithDelay(i, length, fn, delay);
}
}, delay);
})(startIndex, data.length, functionToRun, timeout);
Versi modifikasi dari jawaban Daniel Vassallo, dengan variabel diekstraksi ke dalam parameter untuk membuat fungsi lebih dapat digunakan kembali:
Pertama mari kita mendefinisikan beberapa variabel penting:
var startIndex = 0;
var data = [1, 2, 3];
var timeout = 3000;
Selanjutnya Anda harus mendefinisikan fungsi yang ingin Anda jalankan. Ini akan melewati i, indeks saat ini dari loop dan panjang dari loop, jika Anda membutuhkannya:
function functionToRun(i, length) {
alert(data[i]);
}
Versi yang dapat dieksekusi sendiri
(function forWithDelay(i, length, fn, delay) {
setTimeout(function () {
fn(i, length);
i++;
if (i < length) {
forWithDelay(i, length, fn, delay);
}
}, delay);
})(startIndex, data.length, functionToRun, timeout);
Versi fungsional
function forWithDelay(i, length, fn, delay) {
setTimeout(function () {
fn(i, length);
i++;
if (i < length) {
forWithDelay(i, length, fn, delay);
}
}, delay);
}
forWithDelay(startIndex, data.length, functionToRun, timeout); // Lets run it