Ben basit bir AJAX sayfada çalışıyorum. sayfa yüklendiğinde, bu PHP sayfasından sonuç almak ve metin kutusunda görüntülemek gerekir. Sonuç (olması gerektiği) "1" ise, o zaman diyerek bir uyarı açılır gerekir "hazır."
Ana sayfanın kod (t1_wait.php):
<html><head><title>Waiting...</title></head><body>
<script type="text/javascript">
function update(id)
{
var xmlhttp;
if (window.XMLHttpRequest){
// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}else if (window.ActiveXObject){
// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}else{
alert("Your browser does not support XMLHTTP!");
}
xmlhttp.onreadystatechange=function(){
if(xmlhttp.readyState==4){
if(xmlhttp.responseText=="1")
alert("Ready!");
}
document.myForm.status.value=xmlhttp.responseText;
}
}
var requesturl = "t1_checkMatch.php?id="+id;
xmlhttp.open("GET",requesturl,true);
xmlhttp.send(null);
// delay for 1 sec
var date = new Date();
var curDate = null;
do { curDate = new Date(); }
while(curDate-date < 1000);
}
<?php
echo "update(".$_GET['id'].");";
?>
</script>
<form name="myForm">
Status: <input type="text" name="status" />
</form>
</body></html>
PHP sayfası (t1_checkMatch.php) (tüm db bilgi * ile değiştirildi) dışarı çağrıldığını:
<?php
$db_user = "*****";
$db_pass = "*****";
$db_name = "*****";
mysql_connect(localhost,$db_user,$db_pass);
@mysql_select_db($db_name) or die("Unable to select database");
$match_id = $_GET['id'];
$match_info = mysql_query("SELECT * FROM ***** WHERE id=".$match_id);
if(mysql_result($match_info,0,"usr2")==-1){
echo "1";
}else{
echo "0";
}
?>
Ben? Id = 16 (GET = 16 ana sayfa geçen id), bu t1_checkMatch.php için (evet, kontrol ettim) 1 döndürür = 16? Id, bir isteği göndermek gerekir t1_wait.php giderken. Bu gerekir metin kutusunda görünmesini "Ready" ve neden 1 söyleyerek bir uyarı tetikler, ancak bunların hiçbiri olur. Metin kutusu boştur.
Ne oldu? Teşekkürler!