JavaScriptでループタイマー
2023-08-10 07:13:26
質問
私は2000ミリ秒ごとにJavaScriptのコードの一部を実行する必要があります。
setTimeout('moveItem()',2000)
上記は2000ミリ秒後に関数を実行し、それ以降は実行しません。
というわけで、moveItem関数の内部には
function moveItem() {
jQuery(".stripTransmitter ul li a").trigger('click');
setInterval('moverItem()',2000);
}
2000ミリ秒ごとにトリガークリックのjQueryコードを実行したいのですが、今はずっと呼び出されていて、スクリプトを中断する必要があるため、これはうまくいきません。それに加えて、これは非常に質の悪いコーディングだと感じています...。皆さんはどのようにこれを解決しますか?
どのように解決するのですか?
以下のことに注意してください。
setTimeout
と
setInterval
は全く異なる機能です。
-
setTimeout
はコードを実行します 一度だけ を実行し、タイムアウトの後に -
setInterval
はコードを実行します。 永遠に を、指定されたタイムアウトの間隔で実行します。
どちらの関数も
タイマーID
を返し、それを使ってタイムアウトを中止することができます。この値を変数に格納し、それを引数として
clearTimeout(tid)
または
clearInterval(tid)
をそれぞれ使用します。
つまり、何をしたいかに応じて、2つの有効な選択肢があるのです。
// set timeout
var tid = setTimeout(mycode, 2000);
function mycode() {
// do some stuff...
tid = setTimeout(mycode, 2000); // repeat myself
}
function abortTimer() { // to be called when you want to stop the timer
clearTimeout(tid);
}
または
// set interval
var tid = setInterval(mycode, 2000);
function mycode() {
// do some stuff...
// no need to recall the function (it's an interval, it'll loop forever)
}
function abortTimer() { // to be called when you want to stop the timer
clearInterval(tid);
}
どちらもごく一般的な実現方法です。
関連
-
[解決済み] JavaScriptで "use strict "は何をするのか、その根拠は?
-
[解決済み] JavaScriptで文字列が部分文字列を含むかどうかを確認する方法は?
-
[解決済み] あるJavaScriptファイルを他のJavaScriptファイルにインクルードするにはどうすればよいですか?
-
[解決済み] JavaScriptでタイムスタンプを取得する方法は?
-
[解決済み] JavaScriptのオブジェクトをループスルーまたは列挙するにはどうすればよいですか?
-
[解決済み】JavaScriptの比較では、どちらの等号演算子(== vs ===)を使うべきですか?
-
[解決済み】オブジェクトからプロパティを削除する(JavaScript)
-
[解決済み] <Enter>でjQuery UIダイアログを送信する
-
[解決済み] bootstrap のポップオーバーがすべての要素の上に表示されない
-
[解決済み] 変異を伴わないオブジェクトからの値の削除
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] Google maps API V3 - 同一地点に複数のマーカーを設置する。
-
[解決済み] Angularjs - 現在の日付を表示する
-
[解決済み] なぜ "use strict "はパフォーマンスを10倍向上させるのか?
-
[解決済み] React js 親コンポーネントから子コンポーネントの状態を変更する
-
[解決済み] jQueryの$という記号の意味は何ですか?
-
[解決済み] ECMAScriptとは?
-
[解決済み] 各オブジェクトに?重複
-
[解決済み] JavaScriptで長い配列を小さい配列に分割する方法
-
[解決済み] Fetch: ステータスがOKでない場合、プロミスを拒否し、エラーをキャッチするか?
-
[解決済み] JavaScriptデータフォーマット/プリティプリンタ