Я работаю над простой страницей AJAX. когда страница загружается, она должна взять результат со страницы PHP и отобразить его в текстовом поле. Если результат равен «1» (что и должно быть), то должно появиться предупреждение «Готов».
Код главной страницы (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, вызываемая для (t1_checkMatch.php) (вся информация о БД заменена на *****):
<?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";
}
?>
Когда я перехожу к t1_wait.php? Id = 16 (главная страница передает id = 16 через GET), он должен отправить запрос к t1_checkMatch.php? Id = 16, который возвращает (да, я проверял) 1 Это должно вызвать предупреждение «Готово» и вызвать появление 1 в текстовом поле, но ничего из этого не происходит. Текстовое поле пустое.
Что не так? Спасибо!