キーポイント
- スクロールイベントを聴くと、ブラウザがスクロールするたびにコールバック関数が実行されるため、パフォーマンスの劣化が発生します。スロットルは、特定の時間間隔でイベントの一定の流れを保証しますが、脱線は一連のイベントを単一のイベントに組み合わせます。 JavaScriptでのイベントスロットリングの実装は複雑になる可能性があり、イベントスロットリングの標準であるLodashのようなサードパーティの実装を使用することをお勧めします。 Lodashのスロットリング関数は、ローリングイベントスロットリングを簡素化し、コールバック関数がイベントの前面および/またはバックエッジで実行されるかどうかを判断するオプションを提供します。
- スロットリングとデバウンスを選択するための鍵は、解決すべき問題の性質を確認することです。スロットルは、スクロールなどの特定の期間内に発生するイベントに適用されますが、デバウンスはイベント間の間隔が重要ではないキープレスなどのイベントに適用されます。
この記事は、Vildan SofticとJulian Motzによってレビューされました。 SitePointコンテンツを最高の状態にしてくれたすべてのSitePointピアレビュアーに感謝します! スクロールイベントを聴くことの危険の1つは、パフォーマンスの劣化です。ブラウザは、ユーザーがスクロールするたびにコールバック関数を実行し、1秒あたり多くのイベントが可能になります。コールバック関数が多くのRedRaw操作を実行する場合、これはエンドユーザーにとって悪いニュースを意味します。特に、スクロールイベントが発生したときなど、ほとんどのビューを再描画する場合、再描画は高価です。
次の例は、この問題を示しています:
codepenの例を見る:スクロールイベントを解除する
パフォーマンスの劣化と発作の傾向に加えて、。この例は、コンピューターがあなたの指示に正確に従っているときに何が起こるかを示しています。背景の色の間にスムーズな遷移はありません。画面は点滅するだけです。不幸なプログラマーは、この世界には希望がないと感じるかもしれません。良い方法はありませんか?
標準イベント
1つの解決策は、イベントを延期し、一度に複数のイベントを管理することです。これを行うのに役立つ2つの一般的に使用される関数があります:スロットリングとデバウンス。
Trustは、特定の時間間隔にわたって一定のイベントの流れを保証し、一連のイベントを1つのイベントに組み合わせることができます。考え方の1つは、スロットリングは時間に基づいているのに対し、デバウンスはイベントに基づいているということです。スロットルは実行されることが保証されていますが、パケットが発生した後にデジターが実行されることは保証されていません。これについてもっと知りたい場合は、脱線とスロットルに関するこの詳細な議論をご覧ください。
de-shaking
debounceは、ajaxのボタンなど、さまざまな問題を解決します。フォームで何かを入力するときに、各キープレスのリクエストを送信するのはなぜですか?よりエレガントなソリューションは、一連のキーを1つのイベントに組み合わせて、AJAXリクエストをトリガーすることです。これは、タイピングの自然なプロセスに準拠し、サーバーリソースを保存します。キープレスの場合、ユーザーが一定の速度で入力しないため、イベント間の間隔は重要ではありません。
trust
debounceの保証はないため、別の方法はローリングイベントをスロットルすることです。スクロールは特定の期間内に発生するため、スロットルするのが適切です。ユーザーがスクロールを開始したら、タイムリーな実行を確保する必要があります。
この手法は、ページの特定の部分にあるかどうかを確認するのに役立ちます。ページのサイズを考えると、コンテンツをスクロールするのに何秒もかかります。これにより、スロットリングは、特定の間隔で1回のみイベントをトリガーできます。イベントスロットリングにより、スクロールエクスペリエンスがスムーズになり、実行が確保されます。
以下は、ネイティブJavaScriptで書かれたシンプルなイベントスロットルです:
function throttle(fn, wait) { var time = Date.now(); return function() { if ((time + wait - Date.now()) < 0) { fn(); time = Date.now(); } } }
この実装は、関数が最初に呼び出される瞬間を追跡する時間変数を設定します。返された関数が呼び出されるたびに、待機中間が通過したかどうかをチェックし、もしそうなら、コールバックをトリガーして時間をリセットします。
codepenで例を見る:ネイティブJSスロットリングの実装
ユーザーライブラリイベントスロットリングには多くの危険があり、自分で書くことはお勧めしません。独自の実装を書くのではなく、サードパーティの実装を使用することをお勧めします。
lodashLodashは、JavaScriptでのイベントスロットリングの事実上の基準です。このライブラリはオープンソースであるため、好きなようにコードを閲覧できます。利点は、ライブラリがモジュール式であるため、必要なものを入手できることです。
lodashのスロットリング機能を使用して、ローリングイベントスロットリングがシンプルになります:
これにより、入ってくるローリングイベントの急流が1000ミリ秒ごとに1回(1秒)に制限されます。
window.addEventListener('scroll', _.throttle(callback, 1000));APIは、次のように最前線とバックエッジのオプションを提供します。
これらのオプションは、コールバック関数がイベントの前面および/またはバックエッジで実行されるかどうかを決定します。
ここでの問題の1つは、前面と背面の両方をfalseに設定した場合、コールバック関数が発射されないことです。フロントエッジをTRUEに設定すると、すぐにコールバック実行を開始してからスロットリングします。これにより、フロントエッジとトレイルエッジの両方をTRUEに設定すると、各間隔の実行が保証されます。
_.throttle(callback, 1, { trailing: true, leading: true });Codepenでデモを表示:スロットルローリングイベント ソースコードを見ると、Throttle()がDebounce()のラッパーであることが興味深いことがわかりました。スロットルは、異なるパラメーターのセットを通過して、目的の動作を変更するだけです。スロットルはMaxWaitを設定します。これは、この長い間待つと実行を保証します。実装の残りの部分は同じままです。
次のイベントスロットリングアドベンチャーで、Lodashがあなたのために良いと思うことを願っています!
結論
スロットリングとデバウンスの鍵は、解決する問題の性質を確認することです。これらの2つのテクノロジーは、異なるユースケースに適しています。答えを見つけるために、ユーザーの観点から質問を見ることをお勧めします。
Lodashを使用する利点は、単純なAPIで多くの複雑さを抽象化することです。良いニュースは、ライブラリ全体を追加せずにプロジェクトでを使用できることです。必要な関数を含むカスタムビルドのみを作成できるツールであるLodash-Cliがあります。イベントスロットリングは、ライブラリ全体のほんの一部です。
ローリングイベント(FAQ)
についてのFAQ- JavaScriptでローリングイベントをスロットリングする目的は何ですか?
JavaScriptのトラストローリングイベントは、WebサイトまたはWebアプリケーションのパフォーマンスを最適化するために使用されるテクノロジーです。ユーザーがWebページでスクロールすると、ブラウザはピクセルの動きごとにスクロールイベントを生成します。これにより、1秒あたりに生成される数百または数千のイベントが発生する可能性があり、Webページのパフォーマンスを大幅に低下させる可能性があります。これらのイベントを絞ることにより、処理するイベントの数を制限し、それによりWebページのパフォーマンスと応答性を改善できます。
- JavaScriptでスロットリングはどのように機能しますか?
- スロットリングとデスシェイキングの違いは何ですか?
- JavaScriptでスロットリングを達成するにはどうすればよいですか?
関数を使用して、JavaScriptでスロットルできます。この関数を使用すると、指定された数ミリ秒単位で関数の実行を遅らせることができます。イベントリスナーを使用してsetTimeout
を使用することにより、イベントハンドラー機能がXミリ秒ごとに1回以上呼び出されないようにすることができます。 setTimeout
- イベントのスクロールに加えて、他のイベントでスロットリングを使用できますか?
- スロットリングの組み込みサポートを提供するライブラリまたはフレームワークはありますか?
- スロットリングの潜在的な欠点は何ですか?
- スロットリングの有効性をテストするにはどうすればよいですか?
スロットリングの前後にWebページのパフォーマンスを測定することにより、スロットリングの有効性をテストできます。これは、ブラウザー開発者ツールを使用して実行できます。これは、イベントの処理にかかる時間など、Webページのパフォーマンスに関する詳細な情報を提供します。
- スロットリングは、他のパフォーマンス最適化手法と組み合わせて使用できますか?
はい、スロットリングは、debounceやrequestAnimationFrame
などの他のパフォーマンス最適化手法と組み合わせて使用できます。これらのテクノロジーを組み合わせることで、Webページのパフォーマンスと応答性をさらに向上させることができます。
- スロットリングに代わるものはありますか?
はい、debounceやrequestAnimationFrame
など、スロットリングにはいくつかの選択肢があります。デバウンスはスロットリングに似ていますが、関数が時間の経過とともに呼び出される回数を制限する代わりに、最後の呼び出し以来特定の時間が経過するまで関数が呼び出されないようにします。 requestAnimationFrame
は、ブラウザにアニメーションを実行するように指示するメソッドであり、ブラウザに指定された関数を呼び出して次の塗り直しの前にアニメーションを更新するように要求します。
以上がクイックヒント:スクロールイベントをスロットルする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

javascriptisnotbuiltoncorc;それは、解釈されていることを解釈しました。

JavaScriptは、フロントエンドおよびバックエンド開発に使用できます。フロントエンドは、DOM操作を介してユーザーエクスペリエンスを強化し、バックエンドはnode.jsを介してサーバータスクを処理することを処理します。 1.フロントエンドの例:Webページテキストのコンテンツを変更します。 2。バックエンドの例:node.jsサーバーを作成します。

PythonまたはJavaScriptの選択は、キャリア開発、学習曲線、エコシステムに基づいている必要があります。1)キャリア開発:Pythonはデータサイエンスとバックエンド開発に適していますが、JavaScriptはフロントエンドおよびフルスタック開発に適しています。 2)学習曲線:Python構文は簡潔で初心者に適しています。 JavaScriptの構文は柔軟です。 3)エコシステム:Pythonには豊富な科学コンピューティングライブラリがあり、JavaScriptには強力なフロントエンドフレームワークがあります。

JavaScriptフレームワークのパワーは、開発を簡素化し、ユーザーエクスペリエンスとアプリケーションのパフォーマンスを向上させることにあります。フレームワークを選択するときは、次のことを検討してください。1。プロジェクトのサイズと複雑さ、2。チームエクスペリエンス、3。エコシステムとコミュニティサポート。

はじめに私はあなたがそれを奇妙に思うかもしれないことを知っています、JavaScript、C、およびブラウザは正確に何をしなければなりませんか?彼らは無関係であるように見えますが、実際、彼らは現代のウェブ開発において非常に重要な役割を果たしています。今日は、これら3つの間の密接なつながりについて説明します。この記事を通して、JavaScriptがブラウザでどのように実行されるか、ブラウザエンジンでのCの役割、およびそれらが協力してWebページのレンダリングと相互作用を駆動する方法を学びます。私たちは皆、JavaScriptとブラウザの関係を知っています。 JavaScriptは、フロントエンド開発のコア言語です。ブラウザで直接実行され、Webページが鮮明で興味深いものになります。なぜJavascrを疑問に思ったことがありますか

node.jsは、主にストリームのおかげで、効率的なI/Oで優れています。 ストリームはデータを段階的に処理し、メモリの過負荷を回避します。大きなファイル、ネットワークタスク、リアルタイムアプリケーションの場合。ストリームとTypeScriptのタイプの安全性を組み合わせることで、パワーが作成されます

PythonとJavaScriptのパフォーマンスと効率の違いは、主に以下に反映されています。1)解釈された言語として、Pythonはゆっくりと実行されますが、開発効率が高く、迅速なプロトタイプ開発に適しています。 2)JavaScriptはブラウザ内の単一のスレッドに限定されていますが、マルチスレッドおよび非同期I/Oを使用してnode.jsのパフォーマンスを改善でき、両方とも実際のプロジェクトで利点があります。

JavaScriptは1995年に発信され、Brandon Ikeによって作成され、言語をCに実現しました。 2。JavaScriptのメモリ管理とパフォーマンスの最適化は、C言語に依存しています。 3. C言語のクロスプラットフォーム機能は、さまざまなオペレーティングシステムでJavaScriptを効率的に実行するのに役立ちます。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

SublimeText3 中国語版
中国語版、とても使いやすい

メモ帳++7.3.1
使いやすく無料のコードエディター

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。
