JavaScriptを使用して、指定された時間が経過した後に関数を実行する方法
組み込みのsetTimeout()
を使用して、JavaScript関数の実行を遅らせることができます。 メソッド。
3秒後にアラートダイアログを表示したいとします。
まず、3秒をミリ秒(ms)、つまり3000msに変換してから、関数を設定する必要があります。
setTimeout(function() {
alert("That’s 3 seconds!")
}, 3000)
上記は匿名(名前のない)関数ですが、1回しか使用できず、説明がないため、実際にはあまり実用的ではありません。
これはまったく同じ機能ですが、名前付きの関数式:
const delayThreeSeconds = function() {
alert("That’s 3 seconds!")
}
setTimeout(delayThreeSeconds, 3000)
これで、delayThreeSeconds
を参照することで、プロジェクトのどこでも遅延関数を再利用できます。 変数。
setTimeout遅延は示唆的であり、正確ではありません
ほとんどの人は、setTimeoutで指定した時間が最小の関数実行遅延であることを知りません。 —実行にかかる正確な量ではありません。
したがって、3000ミリ秒(3秒)を指定すると、関数が実行されるまでにはるかに長い時間がかかる可能性があります。 JavaScriptは同期であるため、一度に1つのタスクを実行します。
したがって、WebサイトにsetTimeout
の前に実行するように設定されている他のJavaScript関数タスクが多数ある場合 機能するには、これらのタスクを最初に完了する必要があり、数ミリ秒から数秒かかる場合があります。
大きな遅延を引き起こす可能性があるのは、関数の1つが外部ソースからの巨大なスクリプトのロードに依存して完了する場合です。これらは、初心者として、または経験豊富な開発者としてさえも陥る可能性のあるトラップの種類です。
これにより、setTimeout
が作成されます やや予測不可能、またはピンポイントの精度が必要な場合は少なくとも信頼性が低い。
この問題を(ほとんど)回避する簡単な方法
プロジェクトに正確なタイミングが重要な特定の機能がある場合は、他の機能の前に実行するように設定します。これにより、少なくとも、最も重要な機能が可能な限り高速に実行されるようになります。
ただし、最も重要な関数が他のコードの前に実行されるように設定されている場合でも、いくつかが存在する可能性があります。 実行遅延。
たとえば、ユーザーがブラウザに多数のアドオン/拡張機能をインストールしている場合です。そのソフトウェアは(とりわけ)JavaScriptで実行され、それがWebサイトのコード実行の遅延を引き起こすかどうかを予測することは不可能です。
これがすべて、パフォーマンスが焦点を当てる重要なトピックである理由であり、すべてのブラウザと複数のデバイスでコードのパフォーマンスをテストすることが、一貫したユーザーエクスペリエンスを提供するために重要である理由です。
知っておきたいこと: 今日学んだことは、setInterval
にも当てはまります メソッドの違いは、繰り返し実行されることです— setTimeout
一度実行します。
-
2つの非同期関数が完了した後に関数を実行する方法-JavaScript
2つの要素の配列があり、その両方の要素が2つの非同期関数であるとします。両方の非同期関数の実行が完了したら、(この質問の目的で)コンソールに何かを印刷するなどの作業を行う必要があります。 この課題にどのように取り組むことができますか? 非同期タスクの完了時にタスクを実行するには、基本的に2つの方法があります- プロミスの使用 非同期/待機関数の使用 ただし、コードに多くの(複数の)非同期関数の処理が含まれている場合、前者のPromise.all関数は後者よりも優れています。 例 以下はコードです- const arr = [ new Promise((re
-
Pythonで高精度に時間を測定する方法は?
時間を高精度で測定するには、time.clock()またはtime.time()関数を使用します。 Pythonのドキュメントには、この関数はベンチマークの目的で使用する必要があると記載されています。 例 import time t0= time.clock() print("Hello") t1 = time.clock() - t0 print("Time elapsed: ", t1 - t0) # CPU seconds elapsed (floating point) 出力 これにより、出力が得られます- Time elapsed: &nbs