多くの Web アプリケーションは、拡張機能を提供するために複数のスクリプトと CSS ファイルの読み込みに依存しています。ただし、同期読み込みではページのレンダリングが大幅に遅くなる可能性があります。この問題に対処するために、これらのリソースを非同期でロードするためのいくつかの方法が存在します。
1 つの方法は、スクリプト タグで async 属性を使用することです。
<code class="html"><script async src="js/jquery-ui-1.8.16.custom.min.js"></script></code>
この属性は、他のリソースの読み込みをブロックせずにスクリプトを実行できることをブラウザーに通知します。ただし、依存関係のあるスクリプトを非同期でロードすると、依然として問題が発生する可能性があることに注意することが重要です。
この例では、importScripts() というカスタム関数を使用して複数のスクリプトをロードしています。スクリプトとスタイルシートを非同期的に処理します。ただし、このコードには、ページがインタラクティブになる前にすべてのリソースがロードされていることを確認するコールバック メカニズムがありません。
JQuery の $.getScript() メソッドは、簡潔なスクリプトを非同期的にロードする方法:
<code class="js">$.getScript('js/jquery-ui-1.8.16.custom.min.js', successCallback);</code>
このメソッドは、ロードされたスクリプトの実行を自動的に処理し、オプションのコールバック関数を提供します。
最新の場合ブラウザでは、Promise オブジェクトを使用して、コールバック ハンドラーを受け入れる非同期読み込み関数を作成できます。
<code class="js">function loadScript(src) { return new Promise(function (resolve, reject) { var s; s = document.createElement('script'); s.src = src; s.onload = resolve; s.onerror = reject; document.head.appendChild(s); }); }</code>
この関数により、成功した読み込みシナリオと失敗した読み込みシナリオの処理が可能になります。
予期しない動作を避けるために、スクリプトとスタイルシートが正しい順序でロードされていることを確認することが重要です。さらに、リソースを非同期でロードすることは、ページのパフォーマンスを最適化するための主要な方法であってはなりません。縮小、圧縮、リクエスト数の削減などの手法も考慮する必要があります。
以上が非同期スクリプト読み込み技術を使用してページの読み込み速度を向上するにはどうすればよいでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。