setInterval を使用して、特定の反復回数の間、10 分の 1 秒ごとに文字列を操作する JavaScript 関数を作成しました。
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 に等しいように見えました。
では、匿名関数が実行されるたびに間隔を調整するにはどうすればよいでしょうか?