ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript のループ クロージャに関する簡単な説明

JavaScript のループ クロージャに関する簡単な説明

高洛峰
リリース: 2017-01-20 13:29:27
オリジナル
980 人が閲覧しました

あるネチズンが質問しました。次の HTML の出力が常に 5 になるのはなぜですか。各 p をクリックする代わりに、対応する 1、2、3、4、5 が警告されます。

<html >  
<head>  
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  
<title>闭包演示</title>  
<script type="text/javascript">  
   
function init() {  
  var pAry = document.getElementsByTagName("p");  
  for( var i=0; i<pAry.length; i++ ) {  
     pAry[i].onclick = function() {  
     alert(i);  
  }  
 }  
}  
</script>  
</head>  
<body onload="init();">  
<p>产品一</p>  
<p>产品二</p>  
<p>产品三</p>  
<p>产品四</p>  
<p>产品五</p>  
</body>  
</html>
ログイン後にコピー

解決策は次のとおりです

1.各段落オブジェクト(p)に変数iを保存します

function init() {  
 var pAry = document.getElementsByTagName("p");  
 for( var i=0; i<pAry.length; i++ ) {  
   pAry[i].i = i;  
   pAry[i].onclick = function() {  
    alert(this.i);  
   }  
 }  
}
ログイン後にコピー

2.変数iを匿名関数自体に保存します

function init2() {  
 var pAry = document.getElementsByTagName("p");  
 for( var i=0; i<pAry.length; i++ ) {   
  (pAry[i].onclick = function() {  
    alert(arguments.callee.i);  
  }).i = i;  
 }  
}
ログイン後にコピー

3、クロージャの層、i は関数パラメータ

function init3() {  
 var pAry = document.getElementsByTagName("p");  
 for( var i=0; i<pAry.length; i++ ) {  
  (function(arg){    
    pAry[i].onclick = function() {    
     alert(arg);  
    };  
  })(i);//调用时参数  
 }  
}
ログイン後にコピー

の形式で内部関数に渡されます。 4. クロージャの層を追加し、i はローカル変数

function init4() {  
 var pAry = document.getElementsByTagName("p");  
 for( var i=0; i<pAry.length; i++ ) {   
  (function () {  
   var temp = i;//调用时局部变量  
   pAry[i].onclick = function() {   
    alert(temp);   
   }  
  })();  
 }  
}
ログイン後にコピー

の形式でメモリ関数に渡されます

5、レスポンスイベントとして関数を返すクロージャの層を追加します(3との微妙な違いに注意してください)

function init5() {  
 var pAry = document.getElementsByTagName("p");  
 for( var i=0; i<pAry.length; i++ ) {   
  pAry[i].onclick = function(arg) {  
    return function() {//返回一个函数  
    alert(arg);  
   }  
  }(i);  
 }  
}
ログイン後にコピー

6. 実際、関数インスタンスが生成されるたびにクロージャが実装されます。生成された

function init6() {  
  var pAry = document.getElementsByTagName("p");  
  for( var i=0; i<pAry.length; i++ ) {   
   pAry[i].onclick = new Function("alert(" + i + ");");//new一次就产生一个函数实例 
  }  
}
ログイン後にコピー

7. 関数を使用して実装する、6との違いに注意してください

function init7() {  
  var pAry = document.getElementsByTagName("p");  
  for( var i=0; i<pAry.length; i++ ) {  
     pAry[i].onclick = Function(&#39;alert(&#39;+i+&#39;)&#39;) 
  }  
}
ログイン後にコピー

上記は、エディターが提供するループクロージャ用のJavaScriptの全内容です。 PHP 中国語 Web サイト~

JavaScript の詳細 ループ クロージャに関連する記事については、PHP 中国語 Web サイトに注目してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート