最近、jQuery のソース コードを見てみたいと思い、このブログ「jQuery ソース コードから学んだ 10 のこと」を見つけました
この記事はこのビデオ ブログに基づいており、いくつかの内容を改良して皆さんと共有します。
注:
この記事は 2010 年に書かれました。著者はビデオ内で言及された内容に基づいて、現在のバージョン 1.11 に対応するいくつかの調整を加えました。また、一部は放棄されました。削除されたコンテンツ ページは削除されました。元の作成者に感謝します
ブラック ボックス/ブラック ボックス
ブラック ボックス システムの概念は、入力が与えられた場合に出力を返すシステムであり、ブラック ボックスは実装プロセス。ここで言うjQueryブラックボックスは、jsグローバル変数ウィンドウにjQueryと$を出力するもので、処理はブラックボックス内にカプセル化されており外界と干渉しません。
jQuery バージョン 1.4 のブラック ボックスは、次のような自己実行関数を使用します
(function( window, undefined){})(window)
著者は、ブラック ボックスを実装するためのより一般的な方法を提供しました
undefined = true; (function(window, document, undefined){ if(foo == undefined) { } })(this, document)
jQuery のブラック ボックスには、unknown と呼ばれる 3 番目の仮パラメータがあります、そして、実パラメータを渡すとき、jsで値が渡されていない仮パラメータは値が渡されず、ブラックボックス内の未定義の正確性が保証されます。 js では、未定義にグローバル プロパティ として値を割り当てることができます (例: 上記のコードの unknown = true
) 自己実行関数モードでブラック ボックスを実装するもう 1 つの利点は、圧縮が容易になることです。次のような状況では、ブラック ボックス内の単純な変数を使用するだけで済みます。
(function(A, B, C)){ B.getElementById('') })(this, document)
著者は、次のような、ページの特定の部分を継続的に更新 (継続的に実行) する匿名関数の自己実行の例を多数挙げました
(function loop(){ doStuff(); $('#update').load('awesomething.php',function(){ loop(); }) //setTimeout(loop, 100) })()
jQuery 1.11 バージョンのブラック ボックスは、新しいファクトリーメソッド、この記事では
noConflict の実装については説明しません
この関数には大きな違いはありません 1.11 バージョンのコードは次のとおりです
var // Map over jQuery in case of overwrite _jQuery = window.jQuery, // Map over the $ in case of overwrite _$ = window.$; jQuery.noConflict = function( deep ) { if ( window.$ === jQuery ) { window.$ = _$; } if ( deep && window.jQuery === jQuery ) { window.jQuery = _jQuery; } return jQuery; };
競合防止の実装は以前のメソッドを保存することであることがわかります。最初に JQuery と $ を呼び出し、次に noConflict が呼び出されたときに、それらに
ネイティブ js 属性の名前付けによる変換を与えます
1.4 バージョンでは、props オブジェクトを使用して、jquery の属性操作とネイティブ js 属性操作
の間の対応関係を保存します
jQuery.extend({ propFix: { "for": "htmlFor", "class": "className" }, prop: function( elem, name, value ) { //... name = jQuery.propFix[ name ] || name; }, propHooks: { //... } }); jQuery.each([ "tabIndex", "readOnly", "maxLength", "cellSpacing", "cellPadding", "rowSpan", "colSpan", "useMap", "frameBorder", "contentEditable" ], function() { jQuery.propFix[ this.toLowerCase() ] = this; });
propFix this オブジェクトには、クラスからclassNameへの変換など、対応する関係テーブルが格納されており、prop関数はこの関係テーブルの処理を担当します。 以下のそれぞれは非常に興味深いものです。配列内のプロパティを走査し、その小文字形式をそれ自体にマップし、propFix に入れます特殊効果の速度 jQuery の一部のアニメーションでは、直接次のことができることがわかっています。通常、高速、低速を使用してください。 実装速度を定義するには、ソースコードで次のように定義します
jQuery.fx.speeds = { slow: 600, fast: 200, // Default speed _default: 400 };いたずらな原作者は次のことを行いました:
var isIE //... jQuery.fx.speeds._default = isIE ? 800 : 400 jQuery.fx.speeds.veryfast = 200; $('...').fadeIn('veryfast')1つは、デフォルト属性に対して条件判断を行うことです。 "veryfast" などのカスタム速度もあります.readyready 関数 バージョン 1.11 とバージョン 1.4 の間には大きな違いがあります。新しいバージョンでは理解できないことが多くあります。簡単にコアを取り出してみましょう。互換性の理由から見てください
jQuery.ready.promise = function( obj ) { //...省略若干 } else if ( document.addEventListener ) { // 使用addEventListener "DOMContentLoaded" 监听ready事件 document.addEventListener( "DOMContentLoaded", completed, false ); // 备选方案 "load" window.addEventListener( "load", completed, false ); //如果IE } else { // Ensure firing before onload, maybe late but safe also for iframes //IE下 attachEvent 的"onreadystatechange" document.attachEvent( "onreadystatechange", completed ); // A fallback to window.onload, that will always work //备选方案onload window.attachEvent( "onload", completed ); // If IE and not a frame // continually check to see if the document is ready var top = false; try { top = window.frameElement == null && document.documentElement; } catch(e) {} if ( top && top.doScroll ) { (function doScrollCheck() { if ( !jQuery.isReady ) { try { // Use the trick by Diego Perini // http://javascript.nwbox.com/IEContentLoaded/ top.doScroll("left"); } catch(e) { return setTimeout( doScrollCheck, 50 ); } // detach all dom ready events detach(); // and execute any waiting functions jQuery.ready(); } })(); } } } return readyList.promise( obj );}; .ready 利用了下面的.promise去做确保载入完成的工作,重点是document.addEventListener( "DOMContentLoaded", completed, false );window.addEventListener( "load", completed, false );document.attachEvent( "onreadystatechange", completed );window.attachEvent( "onload", completed );
4 つのチェック方法 上から始めると、IE で dom ノードがスクロールがあるかどうかを判断します。スクロールしないと準備完了に影響が出ます。簡単に言うと、jQuery は Diego Perini と呼ばれる技術を使用しています。コメント内のアドレスで詳細を確認できます。 Selector
$('#id').find('tag.thing') --- 高速
$('#id tag.thing') ------- sizzle を使用します
jQuery = function( selector, context ) { // The jQuery object is actually just the init constructor 'enhanced' // Need init if jQuery is called (just allow error to be thrown if not included) return new jQuery.fn.init( selector, context ); }jQuery オブジェクトは実際には init と呼ばれる独自の コンストラクターを返します。 init の動作を見てみましょう
// Initialize a jQuery object init = jQuery.fn.init = function( selector, context ) { var match, elem; // HANDLE: $(""), $(null), $(undefined), $(false) //超级省略...下略 // Handle HTML strings // HANDLE: $(html) -> $(array) // HANDLE: $(html, props) // HANDLE: $(#id) // HANDLE: $(expr, $(...)) // HANDLE: $(expr, context) // HANDLE: $(DOMElement) // HANDLE: $(function) return jQuery.makeArray( selector, this ); }; // Give the init function the jQuery prototype for later instantiation init.prototype = jQuery.fn;
上記で抽出したコード コメントから、HTML タグ名と ID の取得を含め、JQ 独自のコンストラクターでどのような状況が処理されるかがわかります。つまり、これら 2 つの取得は最低レベルです。さらに、$() の他の処理は他の関数を経由する必要があるため、上記の処理ほど効率的ではありません。 同時に、init のプロトタイプが jQuery.fn に割り当てられていることもわかります。興味のある方は、jQuery オブジェクトについて詳しく学ぶことができます。
jQ のステータス セレクター (:not、:has、:eq など) は
以上がjQuery について知っておくべきことは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

PythonとJavaScriptには、コミュニティ、ライブラリ、リソースの観点から、独自の利点と短所があります。 1)Pythonコミュニティはフレンドリーで初心者に適していますが、フロントエンドの開発リソースはJavaScriptほど豊富ではありません。 2)Pythonはデータサイエンスおよび機械学習ライブラリで強力ですが、JavaScriptはフロントエンド開発ライブラリとフレームワークで優れています。 3)どちらも豊富な学習リソースを持っていますが、Pythonは公式文書から始めるのに適していますが、JavaScriptはMDNWebDocsにより優れています。選択は、プロジェクトのニーズと個人的な関心に基づいている必要があります。

C/CからJavaScriptへのシフトには、動的なタイピング、ゴミ収集、非同期プログラミングへの適応が必要です。 1)C/Cは、手動メモリ管理を必要とする静的に型付けられた言語であり、JavaScriptは動的に型付けされ、ごみ収集が自動的に処理されます。 2)C/Cはマシンコードにコンパイルする必要がありますが、JavaScriptは解釈言語です。 3)JavaScriptは、閉鎖、プロトタイプチェーン、約束などの概念を導入します。これにより、柔軟性と非同期プログラミング機能が向上します。

さまざまなJavaScriptエンジンは、各エンジンの実装原則と最適化戦略が異なるため、JavaScriptコードを解析および実行するときに異なる効果をもたらします。 1。語彙分析:ソースコードを語彙ユニットに変換します。 2。文法分析:抽象的な構文ツリーを生成します。 3。最適化とコンパイル:JITコンパイラを介してマシンコードを生成します。 4。実行:マシンコードを実行します。 V8エンジンはインスタントコンピレーションと非表示クラスを通じて最適化され、Spidermonkeyはタイプ推論システムを使用して、同じコードで異なるパフォーマンスパフォーマンスをもたらします。

現実世界におけるJavaScriptのアプリケーションには、サーバー側のプログラミング、モバイルアプリケーション開発、モノのインターネット制御が含まれます。 2。モバイルアプリケーションの開発は、ReactNativeを通じて実行され、クロスプラットフォームの展開をサポートします。 3.ハードウェアの相互作用に適したJohnny-Fiveライブラリを介したIoTデバイス制御に使用されます。

私はあなたの日常的な技術ツールを使用して機能的なマルチテナントSaaSアプリケーション(EDTECHアプリ)を作成しましたが、あなたは同じことをすることができます。 まず、マルチテナントSaaSアプリケーションとは何ですか? マルチテナントSaaSアプリケーションを使用すると、Singの複数の顧客にサービスを提供できます

この記事では、許可によって保護されたバックエンドとのフロントエンド統合を示し、next.jsを使用して機能的なedtech SaaSアプリケーションを構築します。 FrontEndはユーザーのアクセス許可を取得してUIの可視性を制御し、APIリクエストがロールベースに付着することを保証します

JavaScriptは、現代のWeb開発のコア言語であり、その多様性と柔軟性に広く使用されています。 1)フロントエンド開発:DOM操作と最新のフレームワーク(React、Vue.JS、Angularなど)を通じて、動的なWebページとシングルページアプリケーションを構築します。 2)サーバー側の開発:node.jsは、非ブロッキングI/Oモデルを使用して、高い並行性とリアルタイムアプリケーションを処理します。 3)モバイルおよびデスクトップアプリケーション開発:クロスプラットフォーム開発は、反応および電子を通じて実現され、開発効率を向上させます。

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


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

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

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

Dreamweaver Mac版
ビジュアル Web 開発ツール

ドリームウィーバー CS6
ビジュアル Web 開発ツール
