ホームページ ウェブフロントエンド jsチュートリアル Javascript クロージャーの使用例分析_JavaScript スキル

Javascript クロージャーの使用例分析_JavaScript スキル

May 16, 2016 pm 04:18 PM
javascript 使用法 閉鎖

この記事では、JavaScript クロージャーの概念と使用法を例とともに分析します。皆さんの参考に共有してください。詳細は以下の通りです。

クロージャについては、誰もが聞いたことがあるはずです。これが私の簡単な理解です。
正直に言うと、日常業務でクロージャを実際に手動で記述するシナリオはそれほど多くありませんが、プロジェクトで使用されるサードパーティのフレームワークやコンポーネントでは多かれ少なかれクロージャが使用されます。
したがって、クロージャを理解することが非常に必要です。はは…

1. クロージャとは

簡単に言うと、他の関数の内部変数を読み込める関数です。
JSの変数スコープの特性上、内部変数には外部からアクセスできませんが、外部変数には内部からアクセスできます。

2. 使用シナリオ

1. プライベートメンバーを実装します。
2. 名前空間を保護し、グローバル変数の汚染を避けます。
3. 変数をキャッシュします。

まずカプセル化の例を見てみましょう:

コードをコピー コードは次のとおりです。
var person = function () {
//変数のスコープは関数内にあり、外部からはアクセスできません
var name = "デフォルト";

リターン {
getName: function () {
名前を返します;
}、
setName: function (newName) {
name = newName;
}
}
}();

console.log(person.name); // 直接アクセスの場合、結果は次のようになります: unknown
console.log(person.getName()) // 結果は次のようになります:default
console.log(person.setName("langjt"));
console.log(person.getName()); // 結果は次のようになります: langjt

外部変数の参照の問題を解決するには、ループ内で一般的に使用されるクロージャを確認してください。

コードをコピー コードは次のとおりです:
var aLi = document.getElementsByTagName('li');
for (var i=0, len=aLi.length; i aLi[i].onclick = function() {
alert(i); // どの
  • 要素をクリックしても、表示される値は len であり、ここでの i の値が for の後に出力される i の値と同じであることを示します。
    };
    }

  • クロージャーを使用した後:
    コードをコピーします コードは次のとおりです:
    var aLi = document.getElementsByTagName('li');
    for (var i=0, len=aLi.length; i aLi[i].onclick = (function(i) {
    戻り関数() {
    alert(i); // この時点で
  • 要素をクリックすると、対応する添え字がポップアップ表示されます。
    }
    })(i);
    }
  • 3. 注意事項

    1. メモリリーク

    クロージャを使用すると、関数内のすべての変数がメモリに格納され、大量のメモリを消費するため、クロージャを悪用することはできません。悪用しないと、Web ページでパフォーマンスの問題が発生します。
    例:

    コードをコピー コードは次のとおりです。
    function foo() {
    var oDiv = document.getElementById(‘J_DIV’);
    var id = oDiv.id;
    oDiv.onclick = function() {
    //alert(oDiv.id); ここには循環参照があり、IE の低バージョン ページが閉じられた後も oDiv がメモリ内に残っています。したがって、可能な限りオブジェクトではなくプリミティブ型をキャッシュします。
    アラート(id);
    };
    oDiv = null;
    }

    2. 変数の名前付け

    内部関数の変数名と外部関数の変数名が同じ場合、内部関数は外部関数の同じ名前の変数を指すことができなくなります。
    例:

    コードをコピー コードは次のとおりです。
    function foo(num) {
    戻り関数(数値) {
    コンソール.ログ(番号); }
    }
    var f = new foo(9);
    f(); // 未定義

    In fact, the above usage, the professional term is called function currying, is to transform a function that accepts multiple parameters into a function that accepts a single parameter (the first parameter of the original function), and returns the remaining parameters. New function technology that takes parameters and returns a result. Essentially, it also takes advantage of the caching feature of closures, such as:

    Copy code The code is as follows:
    var adder = function(num) {
    Return function(y) {
              return num y;
    };
    };

    var inc = adder(1);
    var dec = adder(-1);
    //inc, dec are now two new functions, their function is to convert the passed parameter value (/‐)1
    alert(inc(99));//100
    alert(dec(101));//100
    alert(adder(100)(2));//102
    alert(adder(2)(100));//102

    Another example is Ali Yubo’s seaJS source code:

    Copy code The code is as follows:
    /**
     * util-lang.js - The minimal language enhancement
     */
    function isType(type) {
    return function(obj) {
    Return {}.toString.call(obj) == "[object " type "]"
    }
    }

    var isObject = isType("Object");
    var isString = isType("String");

    I hope this article will be helpful to everyone’s JavaScript programming design.

    このウェブサイトの声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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衣類リムーバー

    AI Hentai Generator

    AI Hentai Generator

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

    ホットツール

    メモ帳++7.3.1

    メモ帳++7.3.1

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

    SublimeText3 中国語版

    SublimeText3 中国語版

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

    ゼンドスタジオ 13.0.1

    ゼンドスタジオ 13.0.1

    強力な PHP 統合開発環境

    ドリームウィーバー CS6

    ドリームウィーバー CS6

    ビジュアル Web 開発ツール

    SublimeText3 Mac版

    SublimeText3 Mac版

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

    C++ ラムダ式におけるクロージャの意味は何ですか? C++ ラムダ式におけるクロージャの意味は何ですか? Apr 17, 2024 pm 06:15 PM

    C++ では、クロージャは外部変数にアクセスできるラムダ式です。クロージャを作成するには、ラムダ式の外部変数をキャプチャします。クロージャには、再利用性、情報の隠蔽、評価の遅延などの利点があります。これらは、イベント ハンドラーなど、外部変数が破棄されてもクロージャが外部変数にアクセスできる現実の状況で役立ちます。

    C++ラムダ式でクロージャを実装するにはどうすればよいですか? C++ラムダ式でクロージャを実装するにはどうすればよいですか? Jun 01, 2024 pm 05:50 PM

    C++ ラムダ式は、関数スコープ変数を保存し、関数からアクセスできるようにするクロージャーをサポートしています。構文は [キャプチャリスト](パラメータ)->戻り値の型{関数本体} です。 Capture-list は、キャプチャする変数を定義します。[=] を使用してすべてのローカル変数を値によってキャプチャするか、[&] を使用してすべてのローカル変数を参照によってキャプチャするか、[variable1, variable2,...] を使用して特定の変数をキャプチャできます。ラムダ式はキャプチャされた変数にのみアクセスできますが、元の値を変更することはできません。

    C++ 関数におけるクロージャの長所と短所は何ですか? C++ 関数におけるクロージャの長所と短所は何ですか? Apr 25, 2024 pm 01:33 PM

    クロージャは、外部関数のスコープ内の変数にアクセスできる入れ子関数です。その利点には、データのカプセル化、状態の保持、および柔軟性が含まれます。デメリットとしては、メモリ消費量、パフォーマンスへの影響、デバッグの複雑さなどが挙げられます。さらに、クロージャは匿名関数を作成し、それをコールバックまたは引数として他の関数に渡すことができます。

    関数ポインタとクロージャが Golang のパフォーマンスに与える影響 関数ポインタとクロージャが Golang のパフォーマンスに与える影響 Apr 15, 2024 am 10:36 AM

    関数ポインタとクロージャが Go のパフォーマンスに与える影響は次のとおりです。 関数ポインタ: 直接呼び出しよりわずかに遅くなりますが、可読性と再利用性が向上します。クロージャ: 一般に遅いですが、データと動作をカプセル化します。実際のケース: 関数ポインターは並べ替えアルゴリズムを最適化でき、クロージャーはイベント ハンドラーを作成できますが、パフォーマンスの低下をもたらします。

    Java ではクロージャはどのように実装されますか? Java ではクロージャはどのように実装されますか? May 03, 2024 pm 12:48 PM

    Java のクロージャを使用すると、外部関数が終了した場合でも、内部関数が外部スコープの変数にアクセスできるようになります。匿名の内部クラスを通じて実装されると、内部クラスは外部クラスへの参照を保持し、外部変数をアクティブに保ちます。クロージャによりコードの柔軟性が向上しますが、匿名の内部クラスによる外部変数への参照により、それらの変数が存続するため、メモリ リークのリスクに注意する必要があります。

    PHP 関数の連鎖呼び出しとクロージャ PHP 関数の連鎖呼び出しとクロージャ Apr 13, 2024 am 11:18 AM

    はい、コードの単純さと読みやすさは、連鎖呼び出しとクロージャーによって最適化できます。連鎖呼び出しは、関数呼び出しを流暢なインターフェイスにリンクします。クロージャは再利用可能なコード ブロックを作成し、関数の外の変数にアクセスします。

    PHP での POST リクエストの正しい使用法 PHP での POST リクエストの正しい使用法 Mar 27, 2024 pm 03:15 PM

    PHP での POST リクエストの使用は、Web サイト開発における一般的な操作であり、フォーム データ、ユーザー情報などのデータは、POST リクエストを通じてサーバーに送信できます。 POST リクエストを適切に使用すると、データのセキュリティと正確性を確保できます。以下では、PHP での POST リクエストの正しい使用法を紹介し、具体的なコード例を示します。 1. PHP における POST リクエストの基本原則 PHP では、POST メソッドを通じて送信されたデータは、$_POST グローバル変数を使用して取得できます。 POST メソッドはフォーム番号を次のように変換します。

    golangの匿名関数とクロージャの長所と短所のまとめ golangの匿名関数とクロージャの長所と短所のまとめ May 05, 2024 am 09:54 AM

    匿名関数は簡潔で匿名ですが、可読性が低く、デバッグが困難です。クロージャはデータをカプセル化して状態を管理できますが、メモリの消費と循環参照が発生する可能性があります。実際のケース: 匿名関数は単純な数値処理に使用でき、クロージャは状態管理を実装できます。

    See all articles