ホームページ ウェブフロントエンド jsチュートリアル jQuery コア アーキテクチャの設計について話す

jQuery コア アーキテクチャの設計について話す

May 16, 2016 pm 03:07 PM

jQuery は誰にとっても馴染みのあるものではないため、ここでは jQuery が何であるか、またその機能については多くを説明しません。この記事の目的は、ソース コードの簡単な分析を通じて jQuery の核心について説明することです。 、および jQuery が JavaScript の高度な機能を活用して、このような優れた JavaScript ライブラリを構築する方法について説明します。

1 jQuery の最初の紹介

コア関数の観点から見ると、jQuery は 1 つの単純かつ普通のこと、つまりクエリのみを実行します。その構文は非常に簡潔かつ明確であるため、JavaScript が何であるかを知らずに jQuery を使用している人は、一言で言えば「シンプルでシンプル」です。

設計の観点から、jQuery が提供するメソッドは、静的メソッドとインスタンス メソッドの 2 つの主要なカテゴリに分類できます。静的メソッドは、$ を介して直接アクセスされるメソッドです。これらのメソッドは通常、DOM 要素を操作しませんが、ajax リクエストや文字列に対するいくつかの一般的な操作などのいくつかの共通ツールを提供します。さらに、jQuery は独自の拡張メカニズムも提供します。 extend メソッドを通じて必要なコンポーネントを記述します。インスタンス メソッドは静的メソッドとは異なり、jQuery によってクエリされた DOM 要素を操作するために使用されます。jQuery は $() を実行して、クエリされたすべての DOM 要素を配列メソッドに格納します。 this オブジェクトのプロトタイプ チェーンは、これらの DOM を操作するためのメソッドを実装します。たとえば、各 DOM 要素を走査するために each() メソッドが使用されます。

このオブジェクトは「配列として」格納される、つまり、jQuery によって構築されたオブジェクトは配列ではない、と先ほど述べたことにお気づきかもしれません。では、このオブジェクトは正確には何でしょうか? 実際、このオブジェクトは jQuery の核心であり、「jQuery オブジェクト」とも呼ばれます。したがって、この記事の焦点は、jQuery オブジェクトを分析して説明することです。

2 jQuery オブジェクト

通常、jQuery は次のように使用します。

1

2

3

$('div').each(function(index){

  //this ...

});

ログイン後にコピー

$('div') は実行後に戻ります。 jQuery オブジェクト。 each() メソッドは、このオブジェクト内の DOM 要素を走査します。まず $('div') の実行プロセスを見てみましょう (この記事のソース コードは jQuery 3.0 から取得しています):

1

2

3

4

5

jQuery = function( selector, context ) {

  

 return new jQuery.fn.init( selector, context );

 

}

ログイン後にコピー

このメソッドは $('div') のエントリ メソッドです。 $ は jQuery('div') と同等です。 このメソッドが実行することは 1 つだけであることがわかります。 jQuery.fn.init () 関数インスタンス オブジェクトを返すには、jQuery.fn.init とは何でしょうか。次のコードを見てみましょう:

1

2

3

4

5

init = jQuery.fn.init = function( selector, context, root ) {

 //...

 return this;

}

init.prototype = jQuery.fn;

ログイン後にコピー

jQuery.fn.init と init は同じメソッドを参照します。このメソッドは、セレクターが条件を満たす DOM 要素をクエリして返しますが、返される内容は次のとおりです。後で分析します。まず次の文を見てみましょう。

init.prototype = jQuery.fn;
この文は何を意味しますか?この文では、init メソッドのプロトタイプ オブジェクトが jQuery.fn オブジェクトを指すようにしていますが、jQuery.fn とは一体何でしょうか? 引き続きコードを見てみましょう:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

jQuery.fn = jQuery.prototype = {

 

 // The current version of jQuery being used

 jquery: version,

 

 constructor: jQuery,

 

 // The default length of a jQuery object is 0

 length: 0,

 

 // Execute a callback for every element in the matched set.

 each: function( callback ) {

  return jQuery.each( this, callback );

 },

   

 splice: arr.splice

};

ログイン後にコピー

スペースを節約するために、コードの一部を省略しています。ここからわかるように、jQuery.fn は実際には jQuery のプロトタイプ オブジェクトです。オブジェクトは、オブジェクトが動作するメソッドへの参照をいくつか定義します。この時点で少し混乱していると感じても、心配しないでください。アイデアを整理しましょう。jQuery は最初に init メソッドを定義し、次に init プロトタイプ オブジェクト プロトタイプに対する一連の操作メソッドを定義します。最後に、init メソッドのインスタンス オブジェクトが返されます。したがって、上記のプロセスは次のように簡略化できます (擬似コード表現):

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

var init = function(selector,context,root){

 //...

 return this;

}

 

init.prototype = {

 length:0,

 each:function(callback){

  //...

 },

 splice:[].splice

}

 

jQuery = function(selector,context,root){

 

 return new init(selector,context,root);

}

ログイン後にコピー

そこで問題は、なぜ jQuery.fn のメソッドが init のプロトタイプで直接定義されず、プロトタイプで定義されているのかということです。 jQueryの?

実は、これの目的はjQueryのクエリ効率を向上させることです。initのプロトタイプオブジェクトに直接定義すると、クエリを実行するたびにこのような巨大なプロトタイプオブジェクトが作成されてしまいます。このオブジェクトが jQuery のプロトタイプで定義されている場合、このオブジェクトは jQuery がロードされるときに初期化され、今後 $() が実行されるたびに常にメモリ内に存在します。init でプロトタイプをポイントするだけで済みます。毎回同じオブジェクトを作成するのではなく、このオブジェクトを作成します。

init 関数で返される this を見てみましょう。前回のブログで、関数内の this は実行時に常に呼び出し元を指すと述べました。では、init の呼び出し元は誰でしょうか?上記のコードでは呼び出し元が見つからないようですが、この時点で新しいオペレーターの動作の仕組みを深く理解する必要があるので、前回のブログの新しいオペレーターの説明を借りて、 の実行処理を実行します。 new init() は次のように分類されます:

1

2

3

4

5

6

7

8

9

10

11

new init(selector,context,root) = {

 

 var obj = {};

 

 obj.__proto__ = init.prototype;

 

 init.call(obj,selector,context,root);

 

 return typeof result === 'obj'? result : obj;

 

}

ログイン後にコピー

從上述分解過程可以看出,javascript在透過new 來創建一個實例對象的時候,會先創建了一個普通對象obj,然後將obj的內部屬性__proto__指向了init的原型對象,因此obj的原型鏈將會被改變,而第3步使用call方法呼叫init(),所以init中的this指的就是這裡的obj物件。

init()執行以後,會將所有匹配到的DOM物件以數組的方式儲存到this物件中並傳回,也就是傳回了obj對象,而new運算子最終也會將這個obj 對象傳回以作為新的實例物件。所以new運算子傳回的這個實例物件有兩個特點:一是包含了DOM查詢結果集,二是其原型鏈繼承了init的prototype,而init 的prototype 又指向了jQuery.fn對象,因此實例物件也具備了這些操作方法。

jQuery每執行一次查詢就會建立一個jQuery對象,而在同一個應用程式中,所有jQuery物件都會共用同一個jQuery原型物件。因此,jQuery物件不僅包含了DOM查詢結果集,也繼承了jQuery原型物件上的操作方法。這樣,你就可以在查詢後直接呼叫方法來操作這些DOM元素了。這就是jQuery的核心架構設計,簡單、方便、實用!

如果你還不理解上面的講解,不要著急,我按照jQuery的設計思路寫了一個完整的小項目jDate,你可以對比著理解! jDate專案已上傳至GitHub,你可以點擊這裡查看完整程式碼:jDate ,如有不同見解,歡迎討論!

3 jQuery 的缺陷

透過對jQuery的核心架構分析,我們會發現,每執行一次查詢,jQuery就要在記憶體中建立一個複雜的jQuery對象,雖然說每個jQuery對像都共享同一個jQuery原型,但jQuery的查詢過程遠比你想像的要復雜,它既要考慮各種不同的匹配標識,同時又要考慮不同瀏覽器的兼容性。因此,如果你只是對DOM做一些簡單的操作,建議使用原生方法querySelector 替代jQuery,不過在使用原生方法時,對於不同的應用場景你可能要做一些兼容性的工作,你要學會取捨,不要過度依賴jQuery!

以上就是本文的全部內容,希望對大家學習jquery有所啟發,更多相關教程請訪問jQuery視頻教程

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

フロントエンドのサーマルペーパーレシートのために文字化けしたコード印刷に遭遇した場合はどうすればよいですか? フロントエンドのサーマルペーパーレシートのために文字化けしたコード印刷に遭遇した場合はどうすればよいですか? Apr 04, 2025 pm 02:42 PM

フロントエンドのサーマルペーパーチケット印刷のためのよくある質問とソリューションフロントエンド開発におけるチケット印刷は、一般的な要件です。しかし、多くの開発者が実装しています...

javascriptの分解:それが何をするのか、なぜそれが重要なのか javascriptの分解:それが何をするのか、なぜそれが重要なのか Apr 09, 2025 am 12:07 AM

JavaScriptは現代のWeb開発の基礎であり、その主な機能には、イベント駆動型のプログラミング、動的コンテンツ生成、非同期プログラミングが含まれます。 1)イベント駆動型プログラミングにより、Webページはユーザー操作に応じて動的に変更できます。 2)動的コンテンツ生成により、条件に応じてページコンテンツを調整できます。 3)非同期プログラミングにより、ユーザーインターフェイスがブロックされないようにします。 JavaScriptは、Webインタラクション、シングルページアプリケーション、サーバー側の開発で広く使用されており、ユーザーエクスペリエンスとクロスプラットフォーム開発の柔軟性を大幅に改善しています。

誰がより多くのPythonまたはJavaScriptを支払われますか? 誰がより多くのPythonまたはJavaScriptを支払われますか? Apr 04, 2025 am 12:09 AM

スキルや業界のニーズに応じて、PythonおよびJavaScript開発者には絶対的な給与はありません。 1. Pythonは、データサイエンスと機械学習でさらに支払われる場合があります。 2。JavaScriptは、フロントエンドとフルスタックの開発に大きな需要があり、その給与もかなりです。 3。影響要因には、経験、地理的位置、会社の規模、特定のスキルが含まれます。

JavaScriptを使用して、同じIDを持つArray要素を1つのオブジェクトにマージする方法は? JavaScriptを使用して、同じIDを持つArray要素を1つのオブジェクトにマージする方法は? Apr 04, 2025 pm 05:09 PM

同じIDを持つ配列要素をJavaScriptの1つのオブジェクトにマージする方法は?データを処理するとき、私たちはしばしば同じIDを持つ必要性に遭遇します...

JavaScriptは学ぶのが難しいですか? JavaScriptは学ぶのが難しいですか? Apr 03, 2025 am 12:20 AM

JavaScriptを学ぶことは難しくありませんが、挑戦的です。 1)変数、データ型、関数などの基本概念を理解します。2)非同期プログラミングをマスターし、イベントループを通じて実装します。 3)DOM操作を使用し、非同期リクエストを処理することを約束します。 4)一般的な間違いを避け、デバッグテクニックを使用します。 5)パフォーマンスを最適化し、ベストプラクティスに従ってください。

Shiseidoの公式Webサイトのように、視差スクロールと要素のアニメーション効果を実現する方法は?
または:
Shiseidoの公式Webサイトのようにスクロールするページを伴うアニメーション効果をどのように実現できますか? Shiseidoの公式Webサイトのように、視差スクロールと要素のアニメーション効果を実現する方法は? または: Shiseidoの公式Webサイトのようにスクロールするページを伴うアニメーション効果をどのように実現できますか? Apr 04, 2025 pm 05:36 PM

この記事の視差スクロールと要素のアニメーション効果の実現に関する議論では、Shiseidoの公式ウェブサイト(https://www.shisido.co.co.jp/sb/wonderland/)と同様の達成方法について説明します。

Console.log出力の違い結果:なぜ2つの呼び出しが異なるのですか? Console.log出力の違い結果:なぜ2つの呼び出しが異なるのですか? Apr 04, 2025 pm 05:12 PM

Console.log出力の違いの根本原因に関する詳細な議論。この記事では、Console.log関数の出力結果の違いをコードの一部で分析し、その背後にある理由を説明します。 �...

JavaScriptの進化:現在の傾向と将来の見通し JavaScriptの進化:現在の傾向と将来の見通し Apr 10, 2025 am 09:33 AM

JavaScriptの最新トレンドには、TypeScriptの台頭、最新のフレームワークとライブラリの人気、WebAssemblyの適用が含まれます。将来の見通しは、より強力なタイプシステム、サーバー側のJavaScriptの開発、人工知能と機械学習の拡大、およびIoTおよびEDGEコンピューティングの可能性をカバーしています。

See all articles