検索
ホームページウェブフロントエンドjsチュートリアルjQuery でのコード最適化に関する詳細な手順

jQuery でのコード最適化に関する詳細な手順

Jun 09, 2018 am 10:46 AM
jqueryコードの最適化

この記事には、jQuery コードの最適化方法がまとめられています。この分野のニーズがある場合は、一緒に学びましょう。

適切なセレクターを使用する

jQuery では、複数のセレクターを使用して同じ Web ページ要素を選択できます。各セレクターのパフォーマンスは異なり、パフォーマンスの違いを理解する必要があります

1. 最速のセレクター: ID セレクターと要素ラベル セレクター

たとえば、次のステートメントは最高のパフォーマンスを発揮します:

$('#id')
$('form')
$('input')

これらのセレクターに遭遇した場合、 jQuery はブラウザのネイティブ メソッド (getElementById() など) を自動的に呼び出すため、メソッドは迅速に実行されます。

2. 遅いセレクター: クラス セレクター

$('.className') のパフォーマンスはブラウザーによって異なります。 Firefox、Safari、Chrome、Opera ブラウザにはすべてネイティブ メソッド getElementByClassName() があるため、速度は遅くなりません。ただし、IE5 ~ IE8 はこのメソッドをデプロイしていないため、IE

3 ではこのセレクターは非常に遅くなります。最も遅いセレクター: 疑似クラス セレクターと属性セレクター

Web ページ内のすべての非表示の要素を見つけるには、次を使用する必要があります。疑似クラス セレクター:

$(':hidden')

属性セレクターの例:

$('[attribute=value]')

これら 2 つのステートメントは、ブラウザーにネイティブ メソッドがないため、最も遅くなります。ただし、一部の新しいバージョンのブラウザーには、querySelector() メソッドと querySelectorAll() メソッドが追加されており、このタイプのセレクターのパフォーマンスが大幅に向上します

親子関係を理解する

次の 6 つのセレクターはすべて親要素からのものです。

$('.child', $parent)
$parent.find('.child')
$parent.children('.child')
$('#parent > .child')
$('#parent .child')
$('.child', $('#parent'))

でサブ要素を選択する 1. 次のステートメントは、DOM オブジェクトが与えられた場合に、そこからサブ要素を選択することを意味します。 jQuery はこのステートメントを $.parent.find('child') に自動的に変換します。これにより、パフォーマンスがある程度低下します。最速のフォームより 5% ~ 10% 遅くなります

$('.child', $parent)

2 これは最速のステートメントです。 .find() メソッドはブラウザのネイティブ メソッド (getElementById、getElementByName、getElementByTagName など) を呼び出すため、より高速です

$parent.find('.child')

3 このステートメントは $.sibling() と JavaScript の nextSibling( ) メソッドを使用し、ノードをトラバースします一つずつ。 jQuery は内部で Sizzle エンジンを使用してさまざまなセレクターを処理します。シズル エンジンの選択順序は右から左であるため、このステートメントは最初に .child を選択し、次に親要素 #parent を 1 つずつフィルターで除外するため、最速の形式よりも約 70% 遅くなります

$parent.children('.child')

5. これ このステートメントは前のステートメントと同じです。ただし、前のものは直接のサブ要素のみを選択しますが、このものはマルチレベルのサブ要素を選択できるため、最速のフォーム

$('#parent > .child')

6 よりも約 77% 遅くなります。jQuery はこのステートメントを内部で $ に変換します。 ('#parent').find('.child') ですが、これは最速の形式より 23% 遅いです

$('#parent .child')

したがって、最良の選択は $parent.find('.child') です。また、$parent は前の操作で生成されることが多いため、jQuery がキャッシュするため、jQuery がどれほど高速であっても、ネイティブ JavaScript メソッドとは比較にならないため、実行速度はさらに高速化されます。したがって、使用できるネイティブ メソッドがある場合は、jQuery の使用を避けるようにしてください。

最も単純なセレクターを例にとると、 document.getElementById("foo") は $("#foo") よりも 10 倍以上高速です

クリック イベントを処理する関数を a にバインドする別の例を見てみましょうelement :

$('.child', $('#parent'))

このコードの意味は、a 要素をクリックすると、要素の id 属性がポップアップすることです。この属性を取得するには、jQuery を 2 回続けて呼び出す必要があります。1 回目は $(this)、2 回目は attr('id') です。

実はこの処理は全く不要です。より正しい書き方は、ネイティブ JavaScript メソッドを直接使用して this.id を呼び出すことです:

$('a').click(function(){
    alert($(this).attr('id'));
  });

テストによると、this.id の速度は $(this).attr('id よりも 20 倍以上高速です) ')

しっかりキャッシュしましょう

特定の Web ページ要素を選択するのは、コストのかかるステップです。したがって、セレクターの使用回数はできるだけ少なくし、将来繰り返し使用できるように、選択した結果をできるだけ多くキャッシュする必要があります。

例えば、次のような書き方は悪い書き方です:

$('a').click(function(){
    alert(this.id);
  });

より良い書き方は:

jQuery('#top').find('p.classA');
jQuery('#top').find('p.classB');

テストによると、キャッシュした方がキャッシュしない場合よりも2~3倍高速です

jQueryの大きな特徴それは、チェーン書き込みメソッドを使用できるようにすることです

var cached = jQuery('#top');
  cached.find('p.classA');
  cached.find('p.classB');

チェーン書き込みメソッドを使用すると、jQuery が各ステップの結果を自動的にキャッシュするため、非チェーン書き込みメソッドよりも高速になります。テストによると、チェーン書き込み方式は非チェーン書き込み方式 (キャッシュなし) より約 25% 高速です

イベント委任

JavaScript のイベント モデルは「バブル」モード、つまり、子要素はレベルごとに「バブル」し、親要素のイベントになります。

これを使用すると、イベントバインディングを大幅に簡素化できます。たとえば、100 個のセル (td 要素) を持つテーブル (table 要素) があり、各セルにクリック イベント (click) をバインドする必要があります。次のコマンドを 100 回実行する必要がありますか?

$('p').find('h3').eq(2).html('Hello');

答えは「いいえ」です。td 要素でクリック イベントが発生した後、イベントは親要素のテーブルに「バブル」されて監視されるため、このイベントをテーブル要素にバインドするだけで済みます

因此,这个事件只需要在父元素绑定1次即可,而不需要在子元素上绑定100次,从而大大提高性能。这就叫事件的"委托处理",也就是子元素"委托"父元素处理这个事件

$("table").on("click", "td", function(){
    $(this).toggleClass("click");
  });

更好的写法,则是把事件绑定在document对象上面

$(document).on("click", "td", function(){
    $(this).toggleClass("click");
  });

如果要取消事件的绑定,就使用off()方法

$(document).off("click", "td");

少改动DOM

1、改动DOM结构开销很大,因此不要频繁使用.append()、.insertBefore()和.insetAfter()这样的方法

如果要插入多个元素,就先把它们合并,然后再一次性插入。根据测试,合并插入比不合并插入,快了将近10倍

2、如果要对一个DOM元素进行大量处理,应该先用.detach()方法,把这个元素从DOM中取出来,处理完毕以后,再重新插回文档。根据测试,使用.detach()方法比不使用时,快了60%

3、如果要在DOM元素上储存数据,不要写成下面这样:

var elem = $('#elem');
elem.data(key,value);

而要写成

var elem = $('#elem');
$.data(elem[0],key,value);

根据测试,后一种写法要比前一种写法,快了将近10倍。因为elem.data()方法是定义在jQuery函数的prototype对象上面的,而$.data()方法是定义jQuery函数上面的,调用的时候不从复杂的jQuery对象上调用,所以速度快得多

4、插入html代码的时候,浏览器原生的innterHTML()方法比jQuery对象的html()更快

尽量少生成jQuery对象

每当使用一次选择器(比如$('#id')),就会生成一个jQuery对象。jQuery对象是一个很庞大的对象,带有很多属性和方法,会占用不少资源。所以,尽量少生成jQuery对象

举例来说,许多jQuery方法都有两个版本,一个是供jQuery对象使用的版本,另一个是供jQuery函数使用的版本。下面两个例子,都是取出一个元素的文本,使用的都是text()方法

既可以使用针对jQuery对象的版本:

var $text = $("#text");
var $ts = $text.text();

也可以使用针对jQuery函数的版本:

var $text = $("#text");
var $ts = $.text($text);

由于后一种针对jQuery函数的版本不通过jQuery对象操作,所以相对开销较小,速度比较快

选择作用域链最短的方法

严格地说,这一条原则对所有Javascript编程都适用,而不仅仅针对jQuery

我们知道,Javascript的变量采用链式作用域。读取变量的时候,先在当前作用域寻找该变量,如果找不到,就前往上一层的作用域寻找该变量。这样的设计,使得读取局部变量比读取全局变量快得多

请看下面两段代码,第一段代码是读取全局变量:

var a = 0;
  function x(){
    a += 1;
  }

第二段代码是读取局部变量:

function y(){
    var a = 0;
    a += 1;
  }

第二段代码读取变量a的时候,不用前往上一层作用域,所以要比第一段代码快五六倍

同理,在调用对象方法的时候,closure模式要比prototype模式更快

prototype模式:

var X = function(name){ this.name = name; }
X.prototype.get_name = function() { return this.name; };

closure模式:

var Y = function(name) {
    var y = { name: name };
    return { 'get_name': function() { return y.name; } };
  };

同样是get_name()方法,closure模式更快

使用Pub/Sub模式管理事件

当发生某个事件后,如果要连续执行多个操作,最好不要写成下面这样:

function doSomthing{
    doSomethingElse();
    doOneMoreThing();
  }

而要改用事件触发的形式:

function doSomething{
    $.trigger("DO_SOMETHING_DONE");
  }
  $(document).on("DO_SOMETHING_DONE", function(){
    doSomethingElse(); 
  });

还可以考虑使用deferred对象

function doSomething(){
    var dfd = new $.Deferred();
    //Do something async, then... 
    //dfd.resolve();
    return dfd.promise();
  }
  function doSomethingElse(){
    $.when(doSomething()).then(//The next thing);
  }

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在微信小程序中如何使用switch开关选择器

在JavaScript中如何计算多边形质心

在Angular19中有关自定义表单控件使用

以上がjQuery でのコード最適化に関する詳細な手順の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
node.jsは、型を使用してストリーミングしますnode.jsは、型を使用してストリーミングしますApr 30, 2025 am 08:22 AM

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

Python vs. JavaScript:パフォーマンスと効率の考慮事項Python vs. JavaScript:パフォーマンスと効率の考慮事項Apr 30, 2025 am 12:08 AM

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

JavaScriptの起源:その実装言語の調査JavaScriptの起源:その実装言語の調査Apr 29, 2025 am 12:51 AM

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

舞台裏:JavaScriptをパワーする言語は何ですか?舞台裏:JavaScriptをパワーする言語は何ですか?Apr 28, 2025 am 12:01 AM

JavaScriptはブラウザとnode.js環境で実行され、JavaScriptエンジンに依存してコードを解析および実行します。 1)解析段階で抽象的構文ツリー(AST)を生成します。 2)ASTをコンパイル段階のバイトコードまたはマシンコードに変換します。 3)実行段階でコンパイルされたコードを実行します。

PythonとJavaScriptの未来:傾向と予測PythonとJavaScriptの未来:傾向と予測Apr 27, 2025 am 12:21 AM

PythonとJavaScriptの将来の傾向には、1。Pythonが科学コンピューティングの分野での位置を統合し、AI、2。JavaScriptはWebテクノロジーの開発を促進します。どちらもそれぞれのフィールドでアプリケーションシナリオを拡大し続け、パフォーマンスをより多くのブレークスルーを行います。

Python vs. JavaScript:開発環境とツールPython vs. JavaScript:開発環境とツールApr 26, 2025 am 12:09 AM

開発環境におけるPythonとJavaScriptの両方の選択が重要です。 1)Pythonの開発環境には、Pycharm、Jupyternotebook、Anacondaが含まれます。これらは、データサイエンスと迅速なプロトタイピングに適しています。 2)JavaScriptの開発環境には、フロントエンドおよびバックエンド開発に適したnode.js、vscode、およびwebpackが含まれます。プロジェクトのニーズに応じて適切なツールを選択すると、開発効率とプロジェクトの成功率が向上する可能性があります。

JavaScriptはCで書かれていますか?証拠を調べるJavaScriptはCで書かれていますか?証拠を調べるApr 25, 2025 am 12:15 AM

はい、JavaScriptのエンジンコアはCで記述されています。1)C言語は、JavaScriptエンジンの開発に適した効率的なパフォーマンスと基礎となる制御を提供します。 2)V8エンジンを例にとると、そのコアはCで記述され、Cの効率とオブジェクト指向の特性を組み合わせて書かれています。3)JavaScriptエンジンの作業原理には、解析、コンパイル、実行が含まれ、C言語はこれらのプロセスで重要な役割を果たします。

JavaScriptの役割:WebをインタラクティブでダイナミックにするJavaScriptの役割:WebをインタラクティブでダイナミックにするApr 24, 2025 am 12:12 AM

JavaScriptは、Webページのインタラクティブ性とダイナミズムを向上させるため、現代のWebサイトの中心にあります。 1)ページを更新せずにコンテンツを変更できます。2)Domapiを介してWebページを操作する、3)アニメーションやドラッグアンドドロップなどの複雑なインタラクティブ効果、4)ユーザーエクスペリエンスを改善するためのパフォーマンスとベストプラクティスを最適化します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!