我正在尝试使用代码从PHP文件中将MySQL标志设置为true(让我们说A)。我想从另一个已经打开的PHP文件(B)中读取这个MySQL标志。问题是:在更改第一页(A)的标志值后,有没有办法手动刷新此(B)页面?
可能正在使用cron或类似的东西,我真的不想每隔X秒刷新一次页面B,直到它读取新的标志值。
答案 0 :(得分:0)
使用AJAX。
在B页面内创建一个请求函数来检查MySQL标志的状态。如果该标志设置为true
,请刷新页面。
在B程序插入的HTML中:
<head>
...
<script>
function enableChecker() {
setInterval( checkFlag, 10000); // Check each ten seconds
}
function checkFlag() {
xmlhttp = GetXmlHttpObject();
if ( xmlhttp==null ) return;
xmlhttp.onreadystatechange = function() {
if ( xmlhttp.readyState == 4 ) {
if ( xmlhttp.responseText == "OK" ) {
location.reload(); // Refresh the page
}
}
}
xmlhttp.open( 'GET', 'myCheckProgram.php', true ); // Call php program to check the flag value
xmlhttp.send( null );
return false;
}
</script>
</head>
<body onload="enableChecker()" >
创建一个名为myCheckProgram.php的程序
<?php
/* Blah blah to connect with database and query for flag */
$flag = // Result of query
echo $flag ? 'OK' : 'NOK' // Return OK if flag is true
?>