jsクロージャの使い方を詳しく解説_基礎知識
クロージャの使用法を見てみましょう。実際、クロージャを使用すると、さまざまなことができます。たとえば、オブジェクト指向のコーディング スタイルをシミュレートし、コードをよりエレガントかつ簡潔に表現し、いくつかの側面でコードの実行効率を向上させることができます。
1 匿名の自己実行関数
変数はすべてわかっています。var キーワードを追加しない場合、それらはデフォルトでグローバル オブジェクトのプロパティに追加されます。このような一時変数をグローバル オブジェクトに追加すると、多くの欠点があります。
たとえば、他の関数がこれらの変数を誤用する可能性があり、グローバル オブジェクトが大きすぎてアクセス速度に影響を与える可能性があります (変数の値をプロトタイプ チェーンからトラバースする必要があるため)。
変数を使用するたびに var キーワードを使用することに加えて、実際の状況ではこのような状況によく遭遇します。つまり、一部の関数は一度実行するだけでよく、その内部変数は維持する必要がありません。
たとえば、UI の初期化にはクロージャを使用できます:
ツリー: {}
};
(関数(dm){
for(var i = 0; i < dm.table.rows; i ){
var row = dm.table.rows[i]; for(var j = 0; j
// dm.tree を構築
})(データモデル);
内部の変数は外部から参照できないため、匿名関数を作成し、すぐに実行します。 したがって、重要なのは、このメカニズムがグローバル オブジェクトを汚染しないことです。
2 キャッシュ
次に、この関数を呼び出すときに、計算された値を保存する必要があります。見つからない場合は、次に計算します。
次に、キャッシュを更新し、値が見つかった場合は、見つかった値を直接返します。クロージャは外部参照を解放しないため、まさにこれを行います。
コードをコピー
var CachedSearchBox = (function(){
var キャッシュ = {}、
カウント = []; リターン {
AttachSearchBox: function(dsid){
if(dsid in cache){//結果がキャッシュにある場合 キャッシュを返す [dsid] // キャッシュ内のオブジェクトに直接戻ります
var fsb = new uikit.webctrl.SearchBox(dsid);//New
cache[dsid] = fsb;//キャッシュを更新 If (count.length & gt; 100) {// キャッシュのサイズ = 100
cache [count.shift()]を削除します。 return fsb; }、
Clearsearchbox: 関数 (DSID) {
If(キャッシュ内の DSID){
キャッシュ[dsid].clearSelection(); };
})();
CachedSearchBox.attachSearchBox("input1");
このようにして、CachedSearchBox.attachSerachBox("input1") を 2 回目に呼び出すと、
新しい検索ボックス オブジェクトを作成せずに、キャッシュからオブジェクトを取得できます。
3 カプセル化を実装する
まず、カプセル化の例を見てみましょう。内部変数には外部からアクセスできませんが、クロージャを提供することでアクセスできます。
var person = function(){
//変数スコープは関数内にあり、外部からはアクセスできません変数名 = "デフォルト" 変数名
結果は次のようになります:
未定義
デフォルト
アブルッツィ
4 クロージャのもう 1 つの重要な用途は、オブジェクト指向でオブジェクトを実装することです。従来のオブジェクト言語は、クラス テンプレート メカニズム
を提供します。 このように、異なるオブジェクト (クラスのインスタンス) は独立したメンバーと状態を持ち、互いに干渉しません。 JavaScriptにはクラスのような仕組みはありませんが、クロージャを利用することで
このようなメカニズムをシミュレーションすることができます。上の例を見てみましょう:
コードをコピー
コードは次のとおりです:
関数 人(){
変数名 = "デフォルト" 変数名
;
リターン {
getName : function(){ 名前を返す; }、 setName : function(newName){ name = newName; }
};
var john = 人()
print(john.getName()); john.setName("ジョン"); print(john.getName());
var jack = 人(); print(jack.getName()); jack.setName("ジャック"); print(jack.getName());
実行結果は次のとおりです:
デフォルト
ジョン
デフォルト
ジャック
このコードから、john と jack の両方を Person クラスのインスタンスと呼ぶことができることがわかります。これは、2 つのインスタンスが name メンバーに独立してアクセスでき、相互に影響を与えないためです。
上記は 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 のクロージャを使用すると、外部関数が終了した場合でも、内部関数が外部スコープの変数にアクセスできるようになります。匿名の内部クラスを通じて実装されると、内部クラスは外部クラスへの参照を保持し、外部変数をアクティブに保ちます。クロージャによりコードの柔軟性が向上しますが、匿名の内部クラスによる外部変数への参照により、それらの変数が存続するため、メモリ リークのリスクに注意する必要があります。
