我编写了一个 javascript 函数,该函数使用 setInterval 每隔十分之一秒对字符串进行一定次数的迭代操作。
function timer() { var section = document.getElementById('txt').value; var len = section.length; var rands = new Array(); for (i=0; i<len; i++) { rands.push(Math.floor(Math.random()*len)); }; var counter = 0 var interval = setInterval(function() { var letters = section.split(''); for (j=0; j < len; j++) { if (counter < rands[j]) { letters[j] = Math.floor(Math.random()*9); }; }; document.getElementById('txt').value = letters.join(''); counter++ if (counter > rands.max()) { clearInterval(interval); } }, 100); };
我不想将间隔设置为特定数字,而是希望在每次运行时根据计数器对其进行更新。所以而不是:
var interval = setInterval(function() { ... }, 100);
它会是这样的:
var interval = setInterval(function() { ... }, 10*counter);
不幸的是,这并没有奏效。似乎“10 * counter”等于0。
那么,如何在每次匿名函数运行时调整间隔呢?
改为使用setTimeout()。然后回调将负责触发下一次超时,此时您可以增加或以其他方式操纵时间。
setTimeout()
这是一个通用函数,可用于为任何函数调用应用“减速”超时。
function setDeceleratingTimeout(callback, factor, times) { var internalCallback = function(tick, counter) { return function() { if (--tick >= 0) { window.setTimeout(internalCallback, ++counter * factor); callback(); } } }(times, 0); window.setTimeout(internalCallback, factor); }; // console.log() requires firebug setDeceleratingTimeout(function(){ console.log('hi'); }, 10, 10); setDeceleratingTimeout(function(){ console.log('bye'); }, 100, 10);