ホームページ ウェブフロントエンド jsチュートリアル JS クロージャを数分で学習できます

JS クロージャを数分で学習できます

Jan 24, 2017 am 11:08 AM

クロージャは Javascript の重要な概念です。初心者にとって、クロージャは非常に抽象的な概念であり、特に ECMA 仕様で与えられている定義は、実際の経験がなければ、定義から理解するのが困難です。したがって、この記事ではクロージャの概念について長々と説明するのではなく、数分でクロージャを学習できるように実践的な情報に直接進みます。

1 終わりに、見てみましょう

新しいテクノロジーに接したとき、私が最初に行うことは、そのデモ コードを見つけることです。私たちにとって、自然言語よりもコードを見る方が物事の本質をよりよく理解できます。実際、クロージャはいたるところにあります。たとえば、jQuery と zepto のコア コードはすべて大きなクロージャに含まれているため、頭の中でクロージャを生成できるように、最も単純で最も原始的なクロージャを最初に書きます。

function A(){    function B(){
       console.log("Hello Closure!");
    }    return B;
}var C = A();
C();//Hello Closure!
ログイン後にコピー

これが最も単純なクロージャーです。

予備的な理解ができたら、通常の関数とどのように違うのかを簡単に分析してみましょう。 上記のコードを自然言語に翻訳すると、次のようになります。

(1) 通常の関数 A を定義する

(2) A に通常の関数 B を定義する。

(3) A で B を返す

(4) A を実行し、A の戻り結果を変数 C に代入する

(5) C を実行する

これら 5 つのステップを 1 つの文に要約します:

内部に関数 B関数 A は、関数 A の外部の変数 c によって参照されます。

この文を再処理すると、クロージャの定義になります:

内部関数がその外部関数の外側の変数によって参照されるとき、クロージャが形成されます。

つまり、上記の 5 つのステップを実行すると、すでにクロージャが定義されています。

これで閉店です。

2 クロージャの目的

クロージャの機能を理解する前に、まず Javascript の GC メカニズムを理解しましょう:

Javascript では、オブジェクトが参照されなくなった場合、そのオブジェクトは GC リサイクルされ、それ以外の場合は GC リサイクルされます。このオブジェクトは常にメモリに保存されます。

上記の例では、BがAで定義されているため、BはAに依存し、外部変数CがBを参照しているため、AはCによって間接的に参照されます。

言い換えると、A は GC によってリサイクルされず、常にメモリに保存されます。私たちの推論を証明するために、上記の例を少し改良しました:

function A(){    var count = 0;    function B(){
       count ++;
       console.log(count);
    }    return B;
}var C = A();
C();// 1C();// 2C();// 3
ログイン後にコピー
モジュール内でいくつかの変数を定義する必要があり、これらの変数をグローバル変数を「汚染」せずにメモリに保持したい場合は、次のように使用できます。このモジュールを定義するクロージャ。

3 高級な書き方

上記の書き方は実は最も原始的な書き方ですが、実際のアプリケーションではクロージャと匿名関数を併用することになります。以下は、クロージャを記述する一般的に使用される方法です:

(function(document){    var viewport;    var obj = {
        init:function(id){
           viewport = document.querySelector("#"+id);
        },
        addChild:function(child){
            viewport.appendChild(child);
        },
        removeChild:function(child){
            viewport.removeChild(child);
        }
    }
    window.jView = obj;
})(document);
ログイン後にコピー

このコンポーネントの機能は、コンテナを初期化することであり、その後、コンテナにサブコンテナを追加したり、コンテナを削除したりできます。

関数は非常に単純ですが、ここには関数を即時に実行するという別の概念が関係しています。 理解する必要があるのは、この記述メソッドがクロージャ関数をどのように実装するかということです。

上記のコードは 2 つの部分に分割できます:

(function(){}) () 、最初の () は式であり、この式は匿名です関数なので、この式の後に () を追加すると、この匿名関数が実行されることになります。 したがって、このコードの実行プロセスは次のように分解できます:

var f = function(document){    var viewport;    var obj = {
        init:function(id){
            viewport = document.querySelector("#"+id);
        },
        addChild:function(child){
            viewport.appendChild(child);
        },
        removeChild:function(child){
            viewport.removeChild(child);
        }
    }
    window.jView = obj;
};
f(document);
ログイン後にコピー

このコードにはクロージャの影が見られるように見えますが、fには戻り値がなく、クロージャの条件が満たされていると思われますこの文に注意してください。 コード:

window.jView = obj;
ログイン後にコピー

obj は関数 f で定義されたオブジェクトです。このオブジェクトは一連のメソッドを定義します。この変数を obj に指すオブジェクト、つまりグローバル変数 jView は obj を参照し、obj オブジェクト内の関数は関数 f 内の変数 viewport を参照します。したがって、関数 f 内のビューポートは再利用されません。 GC が実行され、ビューポートは常にメモリに保存されるため、この書き方でクロージャ条件が満たされます。

4 簡単なまとめ

これはクロージャの最も単純な理解です。もちろん、クロージャはより深く理解する必要があり、JS の実行コンテキスト、アクティベーション オブジェクト、およびスコープの操作メカニズムを理解する必要があります。そしてスコープチェーン。しかし、初心者としては、今はこれらを理解する必要はありません。簡単に理解した後、実際のプロジェクトで使用することで、自然とクロージャの理解が深まります。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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++ では、クロージャは外部変数にアクセスできるラムダ式です。クロージャを作成するには、ラムダ式の外部変数をキャプチャします。クロージャには、再利用性、情報の隠蔽、評価の遅延などの利点があります。これらは、イベント ハンドラーなど、外部変数が破棄されてもクロージャが外部変数にアクセスできる現実の状況で役立ちます。

推奨: 優れた JS オープンソースの顔検出および認識プロジェクト 推奨: 優れた JS オープンソースの顔検出および認識プロジェクト Apr 03, 2024 am 11:55 AM

顔の検出および認識テクノロジーは、すでに比較的成熟しており、広く使用されているテクノロジーです。現在、最も広く使用されているインターネット アプリケーション言語は JS ですが、Web フロントエンドでの顔検出と認識の実装には、バックエンドの顔認識と比較して利点と欠点があります。利点としては、ネットワーク インタラクションの削減とリアルタイム認識により、ユーザーの待ち時間が大幅に短縮され、ユーザー エクスペリエンスが向上することが挙げられます。欠点としては、モデル サイズによって制限されるため、精度も制限されることが挙げられます。 js を使用して Web 上に顔検出を実装するにはどうすればよいですか? Web 上で顔認識を実装するには、JavaScript、HTML、CSS、WebRTC など、関連するプログラミング言語とテクノロジに精通している必要があります。同時に、関連するコンピューター ビジョンと人工知能テクノロジーを習得する必要もあります。 Web 側の設計により、次の点に注意してください。

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

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

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

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

クロージャによって引き起こされるメモリリークの問題を解決する クロージャによって引き起こされるメモリリークの問題を解決する Feb 18, 2024 pm 03:20 PM

タイトル: クロージャによって引き起こされるメモリ リークと解決策 はじめに: クロージャは JavaScript における非常に一般的な概念であり、内部関数が外部関数の変数にアクセスできるようにします。ただし、クロージャを誤って使用すると、メモリ リークが発生する可能性があります。この記事では、クロージャによって引き起こされるメモリ リークの問題を調査し、解決策と具体的なコード例を提供します。 1. クロージャによるメモリリーク クロージャの特徴は、内部関数が外部関数の変数にアクセスできることです。つまり、クロージャ内で参照される変数はガベージコレクションされません。不適切に使用すると、

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

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

jsとvueの関係 jsとvueの関係 Mar 11, 2024 pm 05:21 PM

js と vue の関係: 1. Web 開発の基礎としての JS、2. フロントエンド フレームワークとしての Vue.js の台頭、3. JS と Vue の補完関係、4. JS と Vue の実用化ビュー。

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

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

See all articles