タイマーによる非同期な関数呼び出しには、window.setTimeout() を使用します。
function puts(text) {
document.write(text);
}
setTimeout(function() {
puts('*');
}, 1000); // Call foo() after 1 second.
一回だけでなく、繰り返し関数を呼び出したい場合は window.setTimeout() の代わりに window.setInterval() を使用します。
function puts(text) {
document.write(text);
}
setInterval(function() {
puts('*');
}, 100);
以下のようなイディオムを使用すれば、window.setTimeout() でも繰り返しのタイマーを実現できます。
function puts(text) {
document.write(text);
}
(function loop() {
puts('*');
setTimeout(loop, 100);
})();
タイマーをキャンセルするには、以下の関数を使用します。
window.clearTimeout(): window.setTimeout() のタイマーをキャンセルするwindow.clearInterval(): window.setInterval() のタイマーをキャンセルするvar id = setTimeout(function() { ... }, 5000);
clearTimeout(id); // タイマーのキャンセル
var id = setInterval(function() { ... }, 5000);
clearInterval(id); // タイマーのキャンセル