刷新 php 页面而不重新加载内容


Refreshing php page without reloading content?

我已经到处搜索了一种方法,其中页面可以每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);
});