ホームページ ウェブフロントエンド jsチュートリアル code_javascript スキルの一部に基づいた Javascript クロージャーに関する簡単な説明

code_javascript スキルの一部に基づいた Javascript クロージャーに関する簡単な説明

May 16, 2016 pm 06:13 PM
javascript 閉鎖

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

function f1(){
var n = 999 ;
nAdd = function(){ n = 1; }
function f2(){
alert(n);
return
}

ここでのクロージャは f1 で、変数 n と関数 f2 を閉じます。

まず nAdd を無視して、元の外観を維持してこの関数を書き直してみましょう。

コードをコピー コードは次のとおりです。
function f1(){
var n = 999 ;
var f2 = function(){alert(n) };
var result =
result(); >

js の各変数は関数単位にカプセル化されます。関数内で変数が見つからない場合、関数はその変数が存在する前の単位 (コンテキスト) を先頭まで検索します。 -レベルのウィンドウドメイン。
このとき疑問が生じます。検索処理は関数参照位置から始まるのか、それとも関数本体定義位置から始まるのか?
上記のコードでは結果の領域はwindowとなっていますが、実際に出力される結果はf1内のn値なので、変数検索の開始点は関数本体が定義されている位置であると言えます。

ここで、nAdd (コードの最初の部分) を見てみましょう。ご存知のとおり、キーワード var を使用せずに定義された変数はデフォルトでウィンドウ ドメインに入ります。そのため、nAdd は実際には window.nAdd になります。これは次のコードと同等です:




コードをコピーします
コードは次のとおりです: var nAdd; function f1(){
var n = 999; }
function f2(){
alert(n); 🎜>}
return function(){ warning(n) };
}


結果の分析によれば、nAdd の実行は n の値に影響します。 f1.




コードをコピーします

コードは次のとおりです: 関数f1(){ var n = 999; nAdd = function(){ n = 1; } function f2(){
alert(n);関数(){ アラート (n) };
var 結果 = f1();
nAdd(); 🎜>
このコード実行の最終出力結果は 1000 です。

この状況をもう一度見てください:




コードをコピーします


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

function f1(){
var n = 999;
nAdd = function(){ n = 1; }
function f2(){
alert(n); } return function(){ アラート(n) }; f1()(); //nAdd(); ()() ; //<--p2
実行プロセスを簡単に説明します:
位置 p1 で、f1 は匿名クロージャ A をカプセル化し、関数 A:f2 を返します。次に、A:f2 が実行され、A:f2 は変数 A:n を出力し、結果は 999 になります。
同時に、A のクロージャーに関数として nAdd が代入され、次の行で nAdd が実行され、A:n の値が 1 に設定されます。
位置 p2 で、f1 は匿名クロージャ B をカプセル化します。実行される操作はすべてクロージャ B に対して行われます。その場合、B:f2 の出力は B:n となるため、最終結果は 999 のままです。
A と B は 2 つの独立した「パッケージ」であり、相互に影響しません。

関数の呼び出し部分を書き換えます:





コードをコピーします

コードは次のとおりです。


関数 f1(){
var n = 999;
nAdd = function(){ n = 1; }
関数 f2(){
alert(n) );
}
関数(){ アラート(n) };
結果 = f1(); ); f1()(); result(); // <--p3 p3 の位置が予期せず 1000 を出力します。
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の 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

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

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

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

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

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

テストにおける golang 関数クロージャの役割 テストにおける golang 関数クロージャの役割 Apr 24, 2024 am 08:54 AM

Go 言語の関数クロージャは単体テストで重要な役割を果たします。 値のキャプチャ: クロージャは外側のスコープ内の変数にアクセスできるため、テスト パラメータをキャプチャしてネストされた関数で再利用できます。テスト コードの簡素化: クロージャは値をキャプチャすることで、ループごとにパラメーターを繰り返し設定する必要性を排除し、テスト コードを簡素化します。可読性の向上: クロージャを使用してテスト ロジックを整理し、テスト コードをより明確で読みやすくします。

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

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

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

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

See all articles