目次
ああ
javascript闭包 by 司徒正美(将临时变量变成某一个对象的属性)
javascript闭包 by 司徒正美(对象闭包)
javascript闭包 by 司徒正美(异常闭包)
ホームページ ウェブフロントエンド jsチュートリアル JavaScript のクロージャーの紹介 (Situ Zhengmei)_JavaScript スキル

JavaScript のクロージャーの紹介 (Situ Zhengmei)_JavaScript スキル

May 16, 2016 pm 06:02 PM
閉鎖

クロージャの定義は非常に曖昧です。クロージャとは、構文ドメインが特定の領域に位置し、外部の実行ドメイン内の非永続変数値を継続的に参照 (読み取りおよび書き込み) する機能を備えた段落を指します。エリア内の独自のスコープ。実行スコープの外にあるこれらの非永続変数は、クロージャが最初に定義された (または作成された) ときの値 (ディープリンク) を魔法のように保持します。簡単に言うと、クロージャは、上位レベルの関数またはスコープから取得した変数 (キーと値のペア) のコピーを別のスコープに保存します。これらのキーと値のペアは、上位レベルの関数の実行には従いません。完成したら。 Zhou Aimin氏は、クロージャは「属性テーブル」であり、クロージャはデータブロックであり、クロージャは「名前=値」を格納する比較テーブルであると、より明確に述べました。それはとても簡単です。ただし、クロージャは実行時の概念であることを強調しておく必要があります。
JavaScript のクロージャには 2 つの特徴があります:
関数変数への参照として - 関数が返されるときにアクティブ化されます。
クロージャは、関数が戻ったときにリソースを解放しないスタック領域です。
現在、認識されているクロージャ実装は 3 つあります:

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

with(obj){
//これがオブジェクト クロージャです
}

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

(function(){
//関数クロージャー
})()

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

try{
//...
} catch( e) {
//catch クロージャーですが IE にはありません
}

いくつかの便利な例
コードをコピーします コードは次のとおりです:

//**************** クロージャ uniqueID******** ********
uniqueID = (function(){ //この関数の呼び出しオブジェクトは値を保存します
var id = 0; //これはプライベート永続値です
//外側の関数は、アクセスできる永続値を返します。 ネストされた関数
//これは、変数 uniqueID に保存したネストされた関数です。 //Return, self。 -increment.
})() ; //定義後に外部関数を呼び出します。
document.writeln(uniqueID());
document.writeln(uniqueID()); //2
document.writeln(uniqueID()); //4




コードをコピー コードは次のとおりです: //****** ************クロージャ階乗** ***********
var a = (function(n){
if(nif( n==1){ return 1; }
else{ return n * argument.callee(n-1); 4);
document.writeln(a);





コードをコピーします
コードは次のとおりです: function User(properties ) { //現在のインスタンスを指すように変数をここで宣言する必要があります
var objthis = this;
for ( var i inproperties ) {
(function(){
//クロージャの内部では、t は毎回 new であり、
var t = property[i] の場合、properties[i] の値が内部にあります。
objthis[ "get" i ] = function() {return t;};objthis[ "set" i ] = function(val) {t = val;})(); }
}
//テストコード
var user = new User({
名前: "ボブ",
年齢: 44
}); getname());
alert(user.getage());
alert(user.getage()); ));
user.setage( 22 );
alert ( user.getage());


が質問です今日、Wuyou で次のことを確認しました:
リクエスト:
これを 3 つのノードの Onclick イベントで、対応するパラメーターを正しくポップアップできます。




コードをコピー

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


  • aa

  • aa
  • ;li id="a3">aa





    Situ Zhengmei による JavaScript クロージャー
    [Ctrl A すべて選択 注: 外部 Js を導入する必要がある場合は、更新して実行する必要があります ] My説明は、onclick バインディング関数 function(){alert(i)} のスコープは、対応する li オブジェクトであり、alert の i のスコープは window です。各ループは window.i の値を書き換えているため、ループの後はが完了すると、i はすでに 4 になり、どの li 要素をクリックしても 4 になります。
    解決策:
    関数クロージャーを使用します。


    var lists = document.getElementsByTagName("li ");
    for(var i=0,l=lists.length; i lists[i].onclick = (function(i){//外部関数に保存
    return function(){
    alert(i);
    }
    })(i)
    }



    コードをコピーします
    コードは次のとおりです。 var lists = document.getElementsByTagName("li"); for(var i=0); ,l=リスト; i < l i ){
    lists[i] = new function(){
    return function(){
    (t 1)
    }
    }
    }





    Situ Zhengmei による JavaScript クロージャー
    [Ctrl A すべて選択 注:
    外部 Js を導入する必要がある場合は、更新して実行する必要があります ] を使用しますイベント プロキシ


    コードをコピー
    コードは次のとおりです。 var ul = document.getElementsByTagName( "ul")[0]; ul.onclick = function(){
    var e = argument[0] ||
    target = e.srcElement ?ターゲット;
    if(target .nodeName.toLowerCase() == "li"){
    alert(target.id.slice(-1))
    }
    }





    Situ Zhengmei による JavaScript クロージャー

    [Ctrl A すべて選択 注: 外部 Js を導入する必要がある場合は、更新して実行する必要があります ] Keepノード上の要素内の一時変数。


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

    var lists = document.getElementsByTagName("li");
    for(var i=0,t=0,el; el = list[i++];){
    el.i = t++
    el.onclick = function(){
    alert(this.i)
    }
    }


    使用with语句造成的对象闭包。
    复制代码 代码如下:

    var els = document.getElementsByTagName("li")
    for(var i=0,n=els.length;iwith ({i:i})
    els[i].onclick = function() { alert(this.innerHTML+i) };
    }


    [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]

    使用try...catch语句构造的异常闭包:
    复制代码 代码如下:

    var lists = document.getElementsByTagName("li");
    for(var i=0,l=lists.length; i < l; i++){
    try{
    throw i;
    }catch(i){
    lists[i].onclick = function(){
    alert(i)
    }
    }
    }


    [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]

    复制代码 代码如下:

    var els = document.getElementsByTagName("li");
    (''+Array(els.length+1)).replace(/./g,function(a,i){
    els[i].onclick=function(){alert(i)}
    })
    このウェブサイトの声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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++ラムダ式でクロージャを実装するにはどうすればよいですか? 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. クロージャによるメモリリーク クロージャの特徴は、内部関数が外部関数の変数にアクセスできることです。つまり、クロージャ内で参照される変数はガベージコレクションされません。不適切に使用すると、

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

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

    クロージャでのメモリリークを効果的に回避するにはどうすればよいでしょうか? クロージャでのメモリリークを効果的に回避するにはどうすればよいでしょうか? Jan 13, 2024 pm 12:46 PM

    クロージャでのメモリリークを防ぐにはどうすればよいでしょうか?クロージャは JavaScript の最も強力な機能の 1 つであり、関数のネストとデータのカプセル化を可能にします。ただし、クロージャでは、特に非同期やタイマーを扱う場合にメモリ リークが発生する傾向があります。この記事では、クロージャでのメモリ リークを防ぐ方法を説明し、具体的なコード例を示します。メモリ リークは通常、オブジェクトが不要になったにもかかわらず、そのオブジェクトが占有しているメモリを何らかの理由で解放できない場合に発生します。クロージャ内で、関数が外部変数を参照する場合、これらの変数は

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

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

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

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

    See all articles