javascript - 使用 HTML 表单值进行 AJAX/PHP MySqli 查询

标签 javascript php html ajax forms

我正在尝试将 AJAX 与 php 和 MySqli 结合使用来从数据库获取结果。我对 ajax 和 javascript 非常陌生,因此我们将不胜感激

这是我的表格:

<form method="get">
    <input type="number" min=0 name="gameId" id="gameId" placeholder="Game Id" required><br>
    <input type="number" min=0 step=0.01 name="price" id="price" placeholder="Price" required><br>
    <button type="submit" onClick="getGames()">Submit</button>
</form>

这是我在 JS 中的 AJAX:

function getGames() {
    var gameId = document.getElementById("gameId").value;
    var price = document.getElementById("price").value;
    if (window.XMLHttpRequest) {
        // code for IE7+, Firefox, Chrome, Opera, Safari
        xmlhttp = new XMLHttpRequest();
    } else {
        // code for IE6, IE5
        xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
    }
    xmlhttp.onreadystatechange = function() {
        if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
            document.getElementById("jumbotron").innerHTML = xmlhttp.responseText;
        }
    };
    xmlhttp.open("GET","getGames.php?gameId="+gameId+"&price="+price, true);
    xmlhttp.send();
}

这是我的 php

    <?php
$servername = "localhost";
$serverusername = "root";
$dbname = "ryangames";

$gameId = intval($_GET["gameId"]);
$price = intval($_GET["price"]);

$conn = mysqli_connect($servername, $serverusername, "", $dbname);
if (!$conn) {
    die("Connection failed: " . mysqli_connect_error());
}

$sql = "SELECT * FROM GAMES WHERE GameId = ".$gameId." AND Price = ".$price; 
$result = mysqli_query($conn, $sql);

if (mysqli_num_rows($result) > 0) {
    while ($row = mysqli_fetch_assoc($result)) {
        echo "<div class=\"gameHolder\">
                <img class=\"gameImg\" src=\"images/".$row["Code"].".png\" alt=\"".$row["Name"]."\">
                <div class=\"gameText\">
                    <h3 class=\"gameName\">".$row["Name"]."</h3>
                    <p class=\"gameDesc\">".$row["Description"]."</p>";
                    if ($row["Price"] == 0) {
                        echo "<p class=\"gamePrice\">FREE</p>";
                    } else {
                        echo "<p class=\"gamePrice\">£".$row["Price"]."</p>";
                    }
        echo"   </div>
            </div>";
    } 
} else {
    echo "0 results";
}

mysqli_close($conn);
?>

我可以看到地址中的值,但没有任何反应。如果我只包含在 php 中并让用户每次刷新,查询就可以工作。

更新:将两个 getElementByIds 更改为末尾有 .value

最佳答案

将按钮从 input type="submit" 更改为 input type="button"

关于javascript - 使用 HTML 表单值进行 AJAX/PHP MySqli 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39109964/

相关文章:

javascript - 使用knockoutjs禁用绑定(bind)

javascript - 使元素在jquery中失去焦点

javascript - 使浏览器窗口在任务栏中闪烁

php - MySQL "INSERT INTO"-错误 : which quotation do I have to use?

php - 使用 php mysql 动态创建带有选项组的选项列表

php - 当输入类型为空时返回 false $this->form_validation->run() ="file"

javascript - 禁用页面上的所有按钮

javascript - 为动态变化的对象创建一个工厂/服务,并且可以将其传递给 Controller

php - 从数据库中检索类别名称

php - 根据列名将查询拆分为多个数组