0
現在、文字と数字の文字列が配列に分割され、ユーザーが定義した一定の時間だけ区切って1つずつ表示します。私は問題に遭遇しましたが、私はmyFunction()を初期化する前に、毎分表示される文字数/数値を設定することができますが、関数が実行されると速度を変更することはできません。関数がすでに実行されている間、速度を変更できるようにするには、コードをどのように変更しますか?setTimeoutループの遅延の変更
var string = "33 a 52 20 82 86 81 7 96 86 c 25 29 44 64 77 D 40 32 55 50 L 65 48 35 21 85 y 46 88 63 55 u 48 65 6 17 37 e 51 53 47 50 a 16 72 M 64 80 P 54 w 43 f 4 67 32 55 79 29 62 11 32 g 47 78 38 42 59 92 x 15 43 61 92 50 57 31 Z 84 69 80 32 9 m 98 22 83 19 12 21 37 28 63 42 73 88 84 75 60";
function myFunction() {
var array = string.split(' ');
for (var i = 0; i < array.length; i++) {
var delay = 60000/(document.getElementById('numPerMinute').value);
(function (str) {
setTimeout(function() {
document.getElementById("displayResults").innerHTML = str;
}, delay * i);
})(array[i]);
}
}
<button onclick="myFunction()">Run</button>
<input type="number" id="numPerMinute"/>
<div id="displayResults"></div>
こんにちは@Arrow、その関数が実行されている間、私はスピードを変更することができるのですか? –
各コールバックは、最初にすべてのコールバックを一度にスケジュールするのではなく、次のコールバックのタイムアウトを設定する再帰的アプローチを使用します。 – Bergi