js_javascript スキルのクロージャに関する簡単な説明
まず、コードの一部を見てみましょう:
111
222
333
var a=document.getElementsByTagName("a");
関数 b(){
for(var i=0;i
アラート(i);
}
}
}
デザインの本来の意図によれば、a タグをクリックすると、それに応じてタグのシリアル番号がポップアップ表示されます。つまり、最初の a をクリックすると 0 が表示され、2 番目の a をクリックすると 1 が表示されます。 ... しかし、実際には常に a のタグが表示されます。その理由は何でしょうか。私はこの問題に長い間悩まされてきましたが、多くの学生がこの問題についての理由を理解していないと思います。不適切な点がございましたら、ご批判、修正をお願いいたします。
私の個人的な理解では、上記の関数が目的を達成できない理由は、イベント処理関数が変数 i にバインドされており、イベント処理関数が onclick に代入されているため、イベント処理関数は次の場合にのみ起動されることになります。 a タグがクリックされるとこの関数が呼び出されるため、論理的に言えば、単純な for ループ内の function(){alert(i);} は実際には実行されず、a ラベルをクリックした時点で for ループはすでに実行されています。実行完了後、このときの i の値が for ループの最終値となります。簡単に理解すると、i の値は b 関数に属し、必要な i の値はリアルタイムでイベント処理関数に渡される値であるということです。では、当初の設計意図を達成する方法はあるのでしょうか?賢い学生なら、クロージャを使用するためだと推測したかもしれません。
別のコードを見てみましょう:
var a=document.getElementsByTagName("a");
関数 b(){
for(var i=0;i
return function(){
アラート(j);
}
}(i);
}
}
b();
上記のコードを実行すると、必要な機能が実装されていることがわかります。つまり、任意のラベルをクリックすると、ラベルが配置されているシリアル番号がポップアップ表示されます。上記のコードについては、多くの学生が同様のバージョンを見たことがあると思いますが、なぜこれを実行することで必要な機能を実現できるのでしょうか? これは単なる個人的な意見です。何か間違っている場合は、お気軽にご指摘ください。
上記のコードの理解の本質は、変数 i の理解です。このコードでは、関数が for ループまで実行され、すぐに呼び出される関数を見つけます。このとき、リアルタイムの i 変数の値がすぐに呼び出される関数に渡され、イベント処理関数も格納されます。リアルタイムの i 変数値。
上記がこの記事の全内容です。皆さんが JS クロージャを理解するのに役立つことを願っています。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









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

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

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

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

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

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

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

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