JSクロージャの使用

php中世界最好的语言
php中世界最好的语言オリジナル
2018-03-19 16:26:513302ブラウズ

今回は JS クロージャーの使用方法について説明します。JS クロージャーを使用する際の 注意事項 は何ですか?実際のケースを見てみましょう。

クロージャ(クロージャ)は

Javascript言語の難しさであり、多くの高度なアプリケーションがクロージャに依存している特徴でもあります。

以下は私の勉強メモです。JavaScript 初心者には非常に役立つはずです。

1.

変数のスコープ

クロージャを理解するには、まずJavaScriptの特殊な変数スコープを理解する必要があります。

変数のスコープは、グローバル変数とローカル変数の2種類にすぎません。

JavaScript 言語の特別な点は、グローバル変数を関数内で直接読み取ることができることです。

var n=999;

function f1(){

alert(n);
}

f1() // 999

; 一方、 のローカル部分を読むことは当然不可能です。関数変数の外側の関数。

function f1(){

var n=999;
}

alert(n); // error

ここで注意すべき点があります。関数内で変数を宣言する場合は、var コマンドを使用する必要があります。これを使用しない場合、実際にはグローバル変数を宣言していることになります。

function f1(){

n=999;
}

f1();

alert(n); // 999

2. ローカル変数を外部から読み取るには?

さまざまな理由により、関数内でローカル変数を取得する必要がある場合があります。ただし、前述したように、これは通常の状況では不可能であり、回避策によってのみ実現できます。

それは、関数の中に関数

を定義することです。 On F1 () { var n = 999;

Function F2 () {

Alert (n) // 999

}}}

上記のコードでは、関数 f1 内のすべてのローカル変数が表示されます。 f2まで。ただし、その逆は機能しません。f2 内のローカル変数は f1 には見えません。これは、JavaScript 言語に特有の「チェーン スコープ」構造で、子オブジェクトはすべての親オブジェクトの変数をレベルごとに検索します。したがって、親オブジェクトのすべての変数は子オブジェクトから見えますが、その逆はありません。

f2 は f1 のローカル変数を読み取ることができるので、f2 が戻り値として使用される限り、f1 の外部にあるその内部変数を読み取ることはできません!

function f1(){

var n=999;

function f2(){

alert(n); // 999

3.クロージャの

前のセクションのコードの f2 関数はクロージャです。


さまざまな専門文献における「閉鎖」の定義は非常に抽象的で、理解するのが困難です。私の理解では、クロージャは他の関数の内部変数を読み取ることができる関数です。

JavaScript言語ではローカル変数を読み込めるのは関数内のサブ関数のみなので、クロージャは単純に「関数内で定義された関数」と理解できます。

つまり、本質的に、クロージャは関数の内部と関数の外部を接続する橋です。

4. クロージャーの使用法

クロージャーはさまざまな場所で使用できます。その最大の用途は 2 つあり、1 つは前述したように関数内の変数を読み取ること、もう 1 つはこれらの変数の値をメモリに保持することです。

この文はどうやって理解できますか?以下のコードを見てください。

function f1(){

var n=999;

nAdd=function(){n+=1}

function f2(){
alert(n);
}

return f2;

var result=f1();

result(); // 999

nAdd();

result(); このコードでは、result は実際にはクロージャ f2 関数です。これは 2 回実行され、1 回目の値は 999、2 回目の値は 1000 でした。これは、関数 f1 のローカル変数 n が常にメモリに格納され、f1 が呼び出された後に自動的にクリアされないことを証明します。

なぜですか?その理由は、f1 が f2 の親関数であり、f2 がグローバル変数に割り当てられているため、f2 は常にメモリ内に存在し、f2 の存在は f1 に依存するため、f1 は常にメモリ内にあり、削除されないためです。呼び出しが完了すると、ガベージ コレクション メカニズム (ガベージ コレクション) によってリサイクルされます。

このコードでもう 1 つ注目すべき点は、「nAdd=function(){n+=1}」という行です。まず、var キーワードが nAdd の前に使用されていないため、nAdd はローカル変数ではなくグローバル変数です。 。次に、nAdd の値は
匿名関数

(匿名関数) であり、この匿名関数自体もクロージャであるため、nAdd は関数の外部で関数内のローカル変数を操作できるセッターと同等です。

5. クロージャを使用する際の注意点

1) クロージャは関数内の変数をメモリに格納し、大量のメモリを消費するため、クロージャを悪用することはできません。そうしないと、Web 上でパフォーマンスの問題が発生します。 IE でメモリ リークが発生する可能性があります。解決策は、関数を終了する前に、未使用のローカル変数をすべて削除することです。 2) クロージャは、親関数内の変数の値を親関数の外で変更します。したがって、親関数をオブジェクト (

オブジェクト

) として使用し、クロージャーをそのパブリック メソッド (パブリック メソッド) として使用し、内部変数をそのプライベート プロパティ (プライベート値) として使用する場合は、変更しないように注意する必要があります。親関数の内部変数の値を何気なく見てみます。

6. 考慮すべき質問 次の 2 つのコードの結果を理解できれば、クロージャの動作メカニズムを理解できたはずです。

コードスニペット 1.

var name = "The Window";

}

};

alert(object.getNameFunc()());

この記事の事例を読んだ後は、この方法を習得したと思います。さらに興味深い情報については、PHP 中国語 Web サイトの他の関連記事にご注目ください。


コード スニペット 2。

var name = "The Window";
  var object = {    name : "My Object",
    getNameFunc : function(){      var that = this;      return function(){        return that.name;      };
    }
  };
  alert(object.getNameFunc()());

推奨読書:


JavaScript文字列の使用方法

WeChatアプレットで双方向データバインディングを実装する方法

以上がJSクロージャの使用の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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