ホームページ ウェブフロントエンド jsチュートリアル JavaScript の匿名関数と Closures_JavaScript スキルの詳細な説明

JavaScript の匿名関数と Closures_JavaScript スキルの詳細な説明

May 16, 2016 pm 04:31 PM
javascript 無名関数 閉鎖

1. 匿名関数
関数は JavaScript で最も柔軟なオブジェクトです。ここでは、匿名関数の使用についてのみ説明します。無名関数:関数名のない関数です。

1.1 関数の定義、まず関数の定義を簡単に紹介します。大きく分けて 3 つの方法があります

最初のタイプ: これも最も一般的なタイプです

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

関数 double(x){
2 * x を返します。 }

2 番目の方法: このメソッドは Function コンストラクターを使用し、パラメーター リストと関数本体の両方を文字列として扱います。これは非常に不便なので、お勧めできません。

コードをコピーします コードは次のとおりです:
var double = new Function('x', 'return 2 * x;');

3 番目のタイプ:

var double = function(x) { return 2* x }

「=」の右側の関数は無名関数であることに注意してください。関数を作成した後、関数は変数 square に代入されます。

1.2 無名関数の作成

最初の方法は、上で述べたように二乗関数を定義することであり、これも最も一般的に使用される方法の 1 つです。

2 番目の方法:

コードをコピーします コードは次のとおりです:
(関数(x, y){
アラート(x y); })(2, 3);


ここ (最初の括弧内) で匿名関数が作成され、2 番目の括弧を使用して匿名関数を呼び出し、パラメーターを渡します。

2. 終了

クロージャを表す英語はクロージャです。クロージャは JavaScript の知識の非常に重要な部分です。クロージャを使用すると、コードの量が大幅に削減され、コードがより明確に見えるなどの効果があるためです。つまり、クロージャは非常に強力です。


クロージャの意味: 端的に言えば、クロージャは関数の入れ子です。たとえ外側の関数が実行されていても、内側の関数は外側の関数のすべての変数を使用できます (これには JavaScript スコープ チェーンが関係します)。

例 1

コードをコピーします コードは次のとおりです:
関数 checkClosure(){
var str = 'レインマン';
setTimeout(
function(){alert(str) } //これは匿名関数です
; 、2000);
}
checkClosure();


この例は非常に単純に見えますが、実行プロセスを注意深く分析すると、まだ多くの知識ポイントがあります。checkClosure 関数の実行は瞬時に行われ (おそらく 0.00001 ミリ秒しかかかりません)、変数 str が関数本体に作成されます。 setTimeout の匿名関数が str への参照を持っているため、 checkClosure の実行後に str は解放されません。 2 秒後、関数本体内の匿名関数が実行され、str が解放されます。

例 2、最適化されたコード

コードをコピーします コードは次のとおりです:
関数 forTimeout(x, y){
アラート(x y);
}
関数遅延(x, y, 時間){
setTimeout('forTimeout(' x ',' y ')' , 時間); }
/**
* 上記の遅延関数は非常に読みにくく、書くのも簡単ではありませんが、クロージャを使用すると、コードをより明確にすることができます
* 関数遅延(x, y, 時間){
* setTimeout(
* 関数(){
* forTimeout(x, y)
* *、時間);
* }
​*/



3. 例
匿名関数の最大の用途は、クロージャ (JavaScript 言語の機能の 1 つ) を作成することです。また、名前空間を構築してグローバル変数の使用を減らすこともできます。
例 3:


コードをコピー

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

var oEvent = {};
(関数(){
var addEvent = function(){ /*コードの実装は省略*/ };
関数removeEvent(){}

oEvent.addEvent = addEvent;
oEvent.removeEvent = 削除イベント;
})();

このコードでは、addEvent 関数とremoveEvent 関数はローカル変数ですが、グローバル変数 oEvent を通じてそれを使用できます。これにより、グローバル変数の使用が大幅に削減され、Web ページのセキュリティが強化されます。 次のコードを使用します: oEvent.addEvent(document.getElementById('box') , 'click' , function(){});

例 4:

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

var レインマン = (関数(x , y){
x y を返します;
})(2, 3);
/**
最初の括弧は読みやすくするだけなので、* は次の形式で記述することもできますが、次の記述形式は推奨されません。
* var レインマン = function(x, y){
* x y を返します;
* }(2, 3);
​*/

ここでは変数 Rainman を作成し、匿名関数を直接呼び出すことでそれを 5 に初期化します。この小さなトリックは場合によっては非常に実用的です。

例 5:

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

var external = null;
(関数(){
var one = 1;
関数内部 (){
1 = 1;
アラート(1);
}
外側 = 内側;
})();
アウター(); //2
アウター(); //3
アウター(); //4

このコードの変数 1 はローカル変数 (関数内で定義されているため) であるため、外部からアクセスできません。ただし、ここでは変数 one にアクセスできる inner 関数を作成し、グローバル変数 external は inner を参照するため、outer を 3 回呼び出すと増分結果がポップアップされます。

4. 注意
4.1 クロージャにより、内部関数は親関数内の変数を参照できますが、変数は最終値

例 6:

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

/**
 *
 *

     *
  • 1

  •  *
  • two

  •  *
  • three

  •  *
  • 1

  •  *

 */

var lists = document.getElementsByTagName('li');
for(var i = 0 , len = lists.length ; i Lists[ i ].onmouseover = function(){
アラート(i); };
}

マウスを各

解決策 1:

コードをコピーします コードは次のとおりです:
var lists = document.getElementsByTagName('li');
for(var i = 0 , len = lists.length ; i (関数(インデックス){
Lists[index].onmouseover = function(){
アラート(インデックス);                                                                      })(i);
}

解決策 2:

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

var lists = document.getElementsByTagName('li');
for(var i = 0, len = lists.length; i Lists[ i ].$$index = i //Dom 要素
に $$index 属性をバインドして添え字を記録します。 Lists[ i ].onmouseover = function(){
アラート(this.$$index); };
}

解決策 3:

コードをコピーします コードは次のとおりです:
関数eventListener(リスト, インデックス){
List.onmouseover = function(){
アラート(インデックス);
};
}
var lists = document.getElementsByTagName('li');
for(var i = 0 , len = lists.length ; i EventListener(lists[ i ] , i);
}

4.2 メモリリーク

クロージャを使用すると、ブラウザでメモリ リークが発生しやすくなり、深刻な場合にはブラウザがハングします。興味がある場合は、

http://www.jb51.net/article/57404 を参照してください。 html

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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++ 匿名関数の使用法と特徴 Apr 19, 2024 am 09:03 AM

ラムダ式とも呼ばれる匿名関数は、名前を指定せず、1 回限りの使用または関数ポインターを渡すために使用される関数です。機能には、匿名性、ワンタイム使用、クロージャ、戻り値の型推論が含まれます。実際には、ソートやその他の 1 回限りの関数呼び出しによく使用されます。

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

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

Golang の匿名関数は複数の値を返すことができますか? Golang の匿名関数は複数の値を返すことができますか? Apr 13, 2024 pm 04:09 PM

はい、Go 言語の匿名関数は複数の値を返すことができます。構文: func(arg1,arg2,...,argN)(ret1,ret2,...,retM){//関数本体}。使用法: 戻り値を受け取るには := 演算子を使用し、複数の値を返すには return キーワードを使用します。

See all articles