xmlhttp.onreadystatechange関数で、編集するIDの名前を渡すにはどうすればよいですか?

StackOverflow https://stackoverflow.com/questions/1425358

  •  07-07-2019
  •  | 
  •  

質問

これが私のコードです。コメントアウトされている行を参照してください。要素ID(スパン)がハードコーディングされると、機能します。 stateChangedに渡される変数を連結してIDを作成すると、機能しません。 stateChangedに変数を渡すことはできませんか?何が問題なのですか?

function multiplePassportPoints(id, counter)
{
xmlhttp=GetXmlHttpObject();
if (xmlhttp==null)
{
alert ("Browser does not support HTTP Request");
return;
}
var url="addmorepoints.php"; 
url=url+"?id="+id+"&c="+counter;
url=url+"&sid="+Math.random();

xmlhttp.onreadystatechange=stateChanged(id,counter);
xmlhttp.open("GET",url,true);
xmlhttp.send(null);
}

function stateChanged(id, counter) 
{
  if (xmlhttp.readyState==4)
  {
    //THIS WORKS (assuming id is 99 and counter is 5:
    //document.getElementById("99_5").innerHTML += xmlhttp.responseText; 

    //BUT I NEED IT TO WORK LIKE THIS:
    document.getElementById(studentID+"_"+counter).innerHTML += xmlhttp.responseText; 
  }
}

ありがとう!

役に立ちましたか?

解決

コードをこれに変更できます

xmlhttp.onreadystatechange = function () {
        stateChanged(id,counter);
    };    

他のヒント

 <script type="text/javascript">
 var i=1;
 function validate(str)
 { 
 xmlHttp=GetXmlHttpObject()
 var url="checkvalidate.php"
 url=url+"?User9="+str
 xmlHttp.onreadystatechange=stateChanged19 
 xmlHttp.open("GET",url,true)
 xmlHttp.send(null)
 }
function stateChanged19() 
 {  

 if (xmlHttp.readyState==4 || xmlHttp.readyState=="complete")
  { 

  document.getElementById("valid"+i)
  .innerHTML=xmlHttp.responseText 
  i=i+1;
   } }
 </script>

前の呼び出しが終了する前に複数回呼び出すことができるより良いメソッド。 multiplePassportPointsを2回呼び出すと、xmlhttpの以前の値が上書きされることに注意してください。次の2つの結果があります。
1-並行性が発生しない場合はすべて正常に動作する(非常に高い可能性)、
2-最初の呼び出しは発生しません(非常に低い可能性ですが、時々発生し、発見および再現が非常に困難になります)

ただし、次のコードはローカル変数を使用しているため、何度も呼び出しても安全です(テストされていません)。

function multiplePassportPoints(id, counter) {
  var xmlhttp=GetXmlHttpObject();
  if (xmlhttp==null)
  {
    alert ("Browser does not support HTTP Request");
    return;
  }

  var url="addmorepoints.php"; 
  url=url+"?id="+id+"&c="+counter;
  url=url+"&sid="+Math.random();

  xmlhttp.onreadystatechange=function() {
    if (xmlhttp.readyState==4) {
      stateChanged(id, data, xmlhttp.responseText);
    }
  };

  xmlhttp.open("GET",url,true);
  xmlhttp.send(null);
}

function stateChanged(id, counter,text) 
{
    document.getElementById(id+"_"+counter).innerHTML += text; 
}
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top