我已经到处搜索了一种方法,其中页面可以每x秒自动重新加载一次,而无需实际重新加载页面的内容,我有php代码(包括一些html)每当新用户加入页面时都会更新我的数据库表。但是,这只有效一次。
PHP代码
<?php
$userOn5 = "SELECT * FROM `usersOn` WHERE name = '$username'";
$query4 = mysql_query($userOn5) or die (mysql_error());
while ($row = mysql_fetch_array($query4)) {
// Gather all $row values into local variables for easier usage in output
$timenow = $row["time"];
}
$user = "SELECT * FROM `user`";
$query3 = mysql_query($user) or die (mysql_error());
while ($row = mysql_fetch_array($query3)) {
$usernow = $row["name"];
}
$secs = time() - $timenow;
mysql_query("UPDATE user SET name = '$user'");
if ($username == $usernow) {
?>
<div id="container" style="display:none;">
我尝试使用元标记,但这会重新加载整个内容,我尝试将整个 php 代码移动到单独的 php 文件中,并尝试将其加载到页面中名为"show"的div 中:
var auto_refresh = setInterval(
function ()
{
$('#show').load('registeruser.php').fadeIn("slow");
}, 10000); // autorefresh the content of the div after
//every 10000 milliseconds(10sec)
基本上,我要做的是每 10 秒重新运行一次 php 代码。帮助?
您的问题很可能是由于浏览器缓存造成的。您可以使用以下解决方法 - 这实际上是 ajax 在使用 cache: false
时所做的:
$(function() {
var auto_refresh = setInterval(function () {
var t = Date.now();
$('#show').load('registeruser.php?t=' + t);
$('#container').fadeIn("slow");
}, 10000);
});
更新
或者,您可以使用以下内容:
$(function() {
var auto_refresh = setInterval(function () {
var t = Date.now();
$('#show').load('registeruser.php?t=' + t).find('> div').fadeIn("slow");
}, 10000);
});