JavaScript HttpRequest始终返回相同的结果

问题描述 投票:1回答:2

我有一个HTML页面JavaScript,它将一个GET请求数据发送到PHP文件,以返回保存在数据库中的所有数据。 PHP回复HTML表 - 工作正常!

但是:如果我点击一个按钮(调用相同的JavaScript函数)来更新我的表以显示新数据,我得到相同的结果(我肯定在表上有新数据)。

如果我通过浏览器手动调用PHP,它会立即向我显示新的结果,此时它也在使用JavaScript(但只有一次)。

这是我的代码的一部分。

HTML / JS:

<button onclick="GetData()"></button>
<div id="test"></div>
<script>

    function GetData(){
        var xhttp = new XMLHttpRequest();
        document.getElementById("test").innerHTML = "";
        xhttp.onreadystatechange = function(){
            if (xhttp.readyState == 4 && xhttp.status == 200){
                document.getElementById("test").innerHTML = xhttp.responseText;

            }
        };

        xhttp.open("GET", "../GetData.php", true);

        xhttp.send();
        }

</script>

PHP:

    //DB details
    $dbHost     = 'localhost';
    $dbUsername = 'lalalala';
    $dbPassword = 'lalalalal';
    $dbName     = 'lalalala';

    //Create connection and select DB
    $db = new mysqli($dbHost, $dbUsername, $dbPassword, $dbName) or die ("UUUUPS");


    $sql = "select name, beschreibung, image, video from data";



    $result = $db->query($sql);


   if ($result->num_rows > 0) {
$return = '<table class ="table table-hover"><thead><tr><th scope="col">Name</th><th scope="col">Beschreibung</th><th scope="col">Bilddatei</th><th scope="col">Video-Url</th></tr></thead><tbody>';
// output data of each row
while($row = $result->fetch_assoc()) {
    $return .= "<tr><td>".$row["name"]."</td><td>".$row["beschreibung"]."</td><td><img src=data:image/png;base64,".base64_encode($row["image"])."/></td><td>".$row["video"]."</tr>";
}
$return .= "</tbody></table>";
 $db->close();
 echo $return;
 } else {
 echo "0 results";
 }

谢谢您的帮助!

javascript php html mysql
2个回答
1
投票

您的浏览器似乎正在缓存您的结果,这就是您查看数据的原因。你可以像这样测试它:

var random = Math.floor(Math.random() * 100);
xhttp.open("GET", "../GetData.php?"+random, true);

如果这有帮助,请查看PHP脚本中的过期标头。此外,你在过时的方式进行查询的方式。这是一种非常PHP4的方式。看看这里:http://php.net/manual/en/book.mysqli.php


0
投票

我想你可能知道这一点,但以防万一。在测试html页面时,您是否浏览过浏览器检查器?特别是该检查器中的网络选项卡。在那里你可以看到来自服务器的实际响应,你可以看到它是从缓存提供还是提取(你甚至可以在那里禁用缓存),也许这有帮助。

亲切的,马克

© www.soinside.com 2019 - 2024. All rights reserved.