2011-12-03 9 views
0

クリックしたときに "count is odd!"に置き換えたいと思っています。または "count is even" しかし、1クリックイベントごとに再初期化されないようにカウントを宣言する必要がありますか?ここJavaScriptで各クリックを再宣言しないようにカウントを宣言する方法は?

は私がして来たものです:

<h1 onclick="var count=1; 
       if (count%2==1) { 
         this.innerHTML='count is odd!'; count++;} 
       else{  
       this.innerHTML='count is even';count++;} "> 
    Click on this text</h1> 

今あなたが見ることができるように何が起こるのか数回のクリックで1であるということです。

答えて

2

これを試すことができます。counter変数はonclickクロージャスコープにあり、すべてのonclickイベントのグローバル変数のように動作します。

var elements = document.getElementsByTagName("h1") 
for (var key in elements) 
{ 
    if (elements.hasOwnProperty(key)) 
    { 
     var counter = 1; 
     elements[key].onclick = function() 
     { 
      var oddEven = (counter++ % 2 == 1) ? "odd" : "even"; 

      elements[key].innerHTML = "count is " + oddEven; 
     } 
    } 
} 

注:onclickインラインコードあなたの要素を必要としません。

+0

はいけないため、各ループとしてのためのインループを使用します。 – hugomg

+0

説明してください、私にはわからないことがあります –

+0

私はあなたが既にhasOwnPropertyチェックが追加されていることを知っていると思いました。 for-inは、オブジェクトのすべてのキーを反復処理します。これには索引以外のものが含まれ、正しい順序であることが保証されていない可能性があります。配列の場合、正しいイディオムは 'var i; (for i = 0; i hugomg

2

このようにマークアップとjavascriptを混ぜるのはかなり悪いです。私はロジックの分離をお勧めします:

<h1 id="myH">Click on this text</h1> 

をし、その後、別のJavaScriptファイルに:

var count = 1; 
window.onload = function() { 
    var myH = document.getElementById('myH'); 
    myH.onclick = function() { 
     if (count % 2 == 1) { 
      myH.innerHTML = 'count is odd!'; 
     } else { 
      myH.innerHTML = 'count is even'; 
     } 
     count++; 
    }; 
}; 
関連する問題