JQueryソースコードからJavaScript関数のapplyメソッドとcallメソッドを解析_javascriptスキル

WBOY
リリース: 2016-05-16 16:35:31
オリジナル
1110 人が閲覧しました

最近 jQuery の $.each メソッドを使用していたときに、 $.each($('div'),function(index,entity){}); のインデックスとエンティティがどこから来たのかを突然考えました。これは必須であり、現在の走査の添え字とインスタンスを知ることができます。そこで、jQuery のソース コードを調べてみたところ、次のことがわかりました。

デバッグの際、赤丸のコードを使ってcallback.call関数を使ったので、比較的詳しい解説がある「JS応用プログラミング」を参考にしました。

まず、function は Function オブジェクトへのポインタであり、関数名は関数へのポインタです。次に、関数本体内にスコープがあり、これが this キーワードです。

このキーワードは、関数が実行されるスコープを指します。例:

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

<スクリプトタイプ="text/javascript">
関数 funcA() {
アラート(これ);
alert("関数 A");
}

上記コードの関数 funcA はグローバル環境で定義されているため、関数本体の this が wi​​ndow オブジェクトになります。

今度は、電話と申し込みについて説明します。 call 関数を例に挙げると、call の最初のパラメータは関数のスコープを変更するもので、後続のパラメータは関数に渡される必須パラメータであり、元の関数のパラメータと一致している必要があります。 >

コードをコピー コードは次のとおりです:
<スクリプトタイプ="text/javascript">
var testO = { 名前: "リリー" };
function funcA(a,b) {
アラート(これ);
alert("関数 A");
}
関数 funcB(a, b) {

funcA.call(testO, a, b);
}

funcB(1,2) //これは testO

になります。

funcB 関数の定義では、funcA の call 関数を呼び出していましたが、このとき、funcA では、最初は window を指していましたが、call の最初のパラメータである testO を指すように変更しました。 。また、call を呼び出すとき、funcA 関数には 2 つのパラメータがあるため、funcA にパラメータを渡したい場合は、パラメータを 1 つずつ指定する必要があります。つまり、次の 2 つのパラメータ a と b を指定するか、最初のパラメータのみを渡すことができます。

つまり: funcA.call(testO); または単に a を渡します: funcA.call(testO,a);

apply と call の唯一の違いは、apply の 2 番目のパラメーターは配列の形式で指定できること、および funcA.apply(testO,[a,b) のようにパラメーターを 1 つずつ指定する必要がないことです。 ])

call と apply の基本的な使用法を紹介した後、これら 2 つの兄弟の実際の使用法、つまり関数が動作する範囲を拡張する方法について説明します。

コードをコピーします コードは次のとおりです:
<スクリプトタイプ="text/javascript">
window.color = "透明";
var testObj = { color: "red" };
関数 testFuc() {

アラート(this.color);
}

$(function () {

1.testFuc() //「透明」をポップアップします
2.testFuc(this) //「未定義」をポップアップします
3.testFuc.call(this.parent) //「透明」をポップアップします
4.testFuc.call(window) //「透明」をポップアップします
5.testFuc.call(testObj) //「赤」をポップアップします
});


上記のコードは、呼び出しの機能を示しています。最初の関数呼び出しでは、これは window をポイントしているため、window の color 属性がポップアップ表示されます。

2 番目の関数も透過的にポップアップされると考える友人もいるかもしれませんが、まずこの関数が $(function(){}); で実行されていることを確認してください。この jQuery 関数は、jQuery を知っている友人にとっては非常に明確です。

$(function(){}); のスコープはドキュメントを指し、その後、testFunc を呼び出してドキュメントの色をポップアップします (もちろん未定義です)。

3番目の関数はtestFuncのthisをドキュメントの親ウィンドウに指しています。もちろんウィンドウの色をポップアップさせるのは問題ありません。

4 番目の関数はより単純で、ウィンドウを渡します

5 番目の関数は testFunc の this を testObj にポイントし、赤色がポップアップします。

この時点では、誰もがその使用方法を理解しているはずですが、それをどのように理解して使用するかは、あなた自身のルーチンによって異なります。

これは私が理解している方法です。この使用法は C# または Java の汎用メソッドと見なすことができます。たとえば、C# メソッド

の定義

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

public void Test(T a, T b) { }

このようにして、メソッドを拡張し、一般的な目的を達成できます。

上記は私個人の見解・意見ですので、間違っている点がございましたらご指摘いただき、一緒に学んでいただければと思います。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート