ホームページ >ウェブフロントエンド >jsチュートリアル >JQuery のヒント(4) JQuery のパフォーマンスを改善するためのヒント_jquery

JQuery のヒント(4) JQuery のパフォーマンスを改善するためのヒント_jquery

WBOY
WBOYオリジナル
2016-05-16 18:38:391448ブラウズ

選択するときは、ID セレクター

から始めるのが最善です。これは、JQuery が内部で ID 選択に document.getElementByID メソッドを使用しており、他のすべての DOM 選択メソッドよりも高速であるため、これは理解しやすいと思います。したがって、$("#") で始めるのが最適です。例:

コードをコピー コードは次のとおりです。 🎜>

class=" d">


;
$(".b .c .d")//遅いもの
$("#a .b .c .d")//速いもの


$() のコンテキストを提供します
$() を使用してページ要素を選択する場合、選択範囲を提供すると、選択時間を短縮できます。つまり、セレクターで狭い範囲内のみをフィルターできるようにします。ページ全体の代わりにページ もちろんフィルタリング時間は短縮されます。これは、$() 関数内のコンテキストとして 2 番目のパラメータを提供することで実現できます



Copy code

コードは次のとおりです。 🎜>
もちろん、jquery 定義 (または js 関数) イベント内で、これを使用してコンテキストを参照できます:




コードをコピー

コードは次のとおりです。
もちろん、ID セレクター、つまり $(" #..") を使用して選択する場合、コンテキスト パラメーターを指定する必要はありません。これは速度には影響しません。

保存。頻繁に使用される JQuery でラップされた要素
タイトルにあるように、$( )ページ要素の選択には時間がかかるため、この無駄は、

などの変数として保存すると回避できます。


コードをコピー


コードは次のとおりです:



  • one
  • ;
  • 2
  • 4



コードからわかるように、複数のコードを避けています。選択を繰り返すとパフォーマンスが向上します:-)



セレクターの使用はできる限り少なくする
JQuery のセレクターは配列指向であるため、次のような条件が許せばセレクターの使用はできるだけ少なくしてください。




コードをコピー

コードは次のとおりです:





ご覧のとおり、セレクターを使用して選択した要素をカンマで区切ったり、複数の要素を選択したりすると、コードがより簡潔になるだけでなく、ただし、作成される JQuery インスタンスの数を減らすことで、パフォーマンスが若干向上します。



ループが多い場合は $().each の使用を避け、for ループを使用してください
$ を使用する ().each メソッドを使用すると、ループを実行する際のプログラミングが容易になります。 $().each を使用する場合、ループの数が少ない場合のパフォーマンスへの影響は無視できますが、数が多い場合、パフォーマンスへの影響は大きくなります。

情報を確認したところ、数値が 1000 未満の場合は、$().each メソッドが使用できるとのことです。使用する必要があります。



DOM に対する操作を可能な限り最小限に抑えます。
ページ上の DOM に対する操作 (ページ上のテキストの挿入や削除など) は比較的負荷が高いため、この変化を最小限に抑えることが、パフォーマンスのベスト プラクティスです。例:

コードをコピー コードは次のとおりです:





最初の例では 100 回変更された DOM には影響しませんが、2 番目の例では DOM が 1 回変更されただけであり、パフォーマンスの違いは明らかです。


JQuery アニメーション効果をブロックできます
場合によっては、JQuery アニメーションをオフにできれば、パフォーマンスを向上させることができます。ブロック方法は次のとおりです。



コードをコピーします コードは次のとおりです。


パラメータが JS オブジェクトである場合は、JQuery に非常に適したオブジェクト
を使用してください。プラグイン、または JQuery の CSS および attr メソッドを使用して、キー/値または JS キー/値オブジェクトのペアをパラメーターとして渡すと、

などの JQuery オブジェクトの作成を減らすことができます。

コードをコピーします
コードは次のとおりです:



もちろん、連結メソッドも使用できます:



コードをコピーします
コードは次のとおりです:



ただし、このメソッドのパフォーマンスは上記のメソッドほど良くありません。2 つのメソッドを使用する必要があり、さらに一時オブジェクトを生成する必要があります。

上記はいくつかのヒントです。 JQueryのパフォーマンスを向上させる
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
前の記事:純粋な CSS_Image 特殊効果で実装された画像上でマウスが移動したときに影効果を追加するコード次の記事:純粋な CSS_Image 特殊効果で実装された画像上でマウスが移動したときに影効果を追加するコード

関連記事

続きを見る