Prototype ソース コードの Enumerable part_prototype の各メソッドの簡単な分析
JavaScript では、この部分は Prototype の作者が Ruby から借用したものであるため、Enumerable の痕跡はまったくありません。また、Enumerable は実際には他のオブジェクトに直接適用される可能性はありません。他のオブジェクトの「親クラス」であると言えます (ただし、Object の extend メソッドを呼び出し、そのメソッドの直接コピーを作成するだけです)。 )。
Ruby については詳しくありませんが、Enumerable のいくつかのメソッドを見ると、Python のメソッドに似ています。
Enumerable の最も重要なメソッドの 1 つは、シーケンスのすべての要素を走査し、対応する処理を実行することです。各メソッドについてよく理解しておく必要があります。ただし、それらのほとんどは配列に適用されます。たとえば、ネイティブ配列の forEach メソッドと jQuery のチェーン呼び出しはすべて each メソッドに依存します。 jQuery セレクターは DOM オブジェクトの配列を返し、返された配列でそれぞれを呼び出して各要素を個別に処理するためです。
通常、それぞれには 2 つのパラメータがあります。1 つは反復処理関数およびメソッドに対応するコンテキストです。
var each = Array.prototype.forEach | | function( iterator,context){
for(var i = 0,len = this.length ; i iterator.call(context,this[i],this); 🎜>}
};
for(var i = 0,len = this.length ; i iterator.call(context,this[i],i ,this) ;
}
};
Array.prototype.print = function(){
this.each(function(item){
console.log(item);
}) ;
}
console.log([1,2,3,4].print());//1,2,3,4
次に、Array.prototype に _each メソッドと each メソッドを実装します。実装 1:
this._each(iterator,context)
}
Array.prototype._each = function (iterator,context){
for(var i = 0,len = this.length ; i < len ; i ){
iterator.call(context,this[i],i,this) ;
}
};
varindex = 0;
this._each(function(value){
iterator.call) (context,value,index );
})
}
したがって、上記の出力例を Enumerable の形式で実装すると、次の結果が得られます:
var Enumerable = {};
Enumerable.each = function(iterator, context) {
var Index = 0;
this._each(function(value){
iterator) .call(context, value, index );
return this;
Enumerable = function(){
this.each(item){
console.log(item);
})
};
Array.prototype._each = function(iterator,context){
for(var i = 0,len = this. length ; i < len ; i ){
iterator.call(context,this[i],i,this);
}; 以下の実装ソースコードが使用されますextend メソッド
for(var key in Enumerable){
Array.prototype[key] =
}; ;//1,2,3,4
それぞれの実装を理解することが、Enumerable オブジェクトを理解するための鍵であり、後続の Array と Hash の両方が Enumerable オブジェクトに組み込まれます。これは非常に重要です。 。
再版が Xiaoxi Shanzi [http://www.cnblogs.com/xesam/] からのものであることを明記してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

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

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

ホットトピック











JavaScript文字列置換法とFAQの詳細な説明 この記事では、javaScriptの文字列文字を置き換える2つの方法について説明します:内部JavaScriptコードとWebページの内部HTML。 JavaScriptコード内の文字列を交換します 最も直接的な方法は、置換()メソッドを使用することです。 str = str.replace( "find"、 "置換"); この方法は、最初の一致のみを置き換えます。すべての一致を置き換えるには、正規表現を使用して、グローバルフラグGを追加します。 str = str.replace(/fi

単純なJavaScript関数は、日付が有効かどうかを確認するために使用されます。 関数isvaliddate(s){ var bits = s.split( '/'); var d = new Date(bits [2] '/' bits [1] '/'ビット[0]); return !!(d &&(d.getmonth()1)== bits [1] && d.getdate()== number(bits [0])); } //テスト var

この記事では、jQueryを使用して、DOM要素の内側のマージン値とマージン値、特に外側の縁と要素の内側の縁の特定の位置を取得して設定する方法について説明します。 CSSを使用して要素の内側と外側の縁を設定することは可能ですが、正確な値を取得するのは難しい場合があります。 // 設定 $( "div.header")。css( "margin"、 "10px"); $( "div.header")。css( "padding"、 "10px"); このコードはそうだと思うかもしれません

この記事では、10個の例外的なjQueryタブとアコーディオンについて説明します。 タブとアコーディオンの重要な違いは、コンテンツパネルの表示方法と非表示にあります。これらの10の例を掘り下げましょう。 関連記事:10 jQueryタブプラグイン

ウェブサイトのダイナミズムと視覚的な魅力を高めるために、10の例外的なjQueryプラグインを発見してください!このキュレーションされたコレクションは、画像アニメーションからインタラクティブなギャラリーまで、多様な機能を提供します。これらの強力なツールを探りましょう。 関連投稿: 1

HTTP-Consoleは、HTTPコマンドを実行するためのコマンドラインインターフェイスを提供するノードモジュールです。 Webサーバー、Web Servに対して作成されているかどうかに関係なく、HTTPリクエストで何が起こっているかをデバッグして正確に確認するのに最適です

このチュートリアルでは、カスタムGoogle検索APIをブログまたはWebサイトに統合する方法を示し、標準のWordPressテーマ検索関数よりも洗練された検索エクスペリエンスを提供します。 驚くほど簡単です!検索をyに制限することができます

次のjQueryコードスニペットを使用して、Divコンテンツがコンテナ要素領域を超えたときにスクロールバーを追加できます。 (デモンストレーションはありません、それを直接firebugにコピーしてください) // d =ドキュメント // w =ウィンドウ // $ = jQuery var contentarea = $(this)、 wintop = contentarea.scrolltop()、 docheight = $(d).height()、 winheight = $(w).height()、 divheight = $( '#c
