【发布时间】:2014-06-28 00:10:10
【问题描述】:
我的目标是使用 AJAX 来显示 php 搜索结果,而无需重新加载页面。
到目前为止,我已经能够得到结果,(我是 ajax 新手,我不知道 jQuery),目前我唯一的问题是我在 html 表中显示的搜索结果出现在页面顶部最重要的是,不在指定的div中。我已使用innerHTML 尝试正确显示它。
这是我的主要代码:
<head>
<script>
function searchResults(title) {
if (title == "") {
document.getElementById("response").innerHTML="";
}
var request= new XMLHttpRequest();
request.onreadystatechange=function() {
if (request.readyState == 4 && request.status == 200) {
var displayDiv= document.getElementById("response");
displayDiv.innerHTML=request.responseText;
}
}
request.open("GET", "functions.php?titleA="+title, true);
request.send();
document.getElementsById("response").innerHTML="Content";
}
</script>
<title>Anime Search</title>
</head>
<body>
<div class="main">
<div class= "header">
<h1>Search your Database</h1>
</div> <!-- close header -->
<div class= "searchA">
<p>Search your Anime database below</p>
<form onSubmit="searchResults(titleA)">
<label>Title</label><input type="text" name="titleA" placeholder="enter title"/>
<input type="submit" value="submit"/>
</form>
<div id="response">
</div> <!-- close response -->
</div> <!-- close searchA -->
</body>
这里是php:
if (isset($_GET["titleA"])) {
$title= $_GET["titleA"];
$connection= connect();
$username= $_SESSION["username"];
$tableA= $username . "_Anime";
$queryA= "SELECT * FROM Anime." . "`$tableA` WHERE Title LIKE '%$title%'";
$resultA= mysqli_query($connection, $queryA);
if ($resultA == false) {
die("no results found");
}
$numRows= mysqli_num_rows($resultA);
echo "<table class= 'tSearch'>
<thead>
<th>Title</th>
<th>Alt Title</th>
<th>Seasons</th>
<th>Episodes</th>
<th>OVA's</th>
<th>Movies</th>
<th>Status</th>
<th>Downloaded</th>
</thead>
<tbody>";
while($row= mysqli_fetch_array($resultA, MYSQLI_BOTH)) {
echo "<tr>";
echo "<td>" . $row["Title"] . "</td>";
echo "<td>" . $row["Alt_Title"] . "</td>";
echo "<td>" . $row["Seasons"] . "</td>";
echo "<td>" . $row["Total_Episodes"] . "</td>";
echo "<td>" . $row["OVAS"] . "</td>";
echo "<td>" . $row["Movies"] . "</td>";
echo "<td>" . $row["Status"] . "</td>";
echo "<td>" . $row["Downloaded"] . "</td>";
echo "</tr>";
}
echo "</tbody>";
echo "</table>";
mysqli_close($connection);
if ($resultA == false) {
echo mysqli_error($connection);
}
}
我当然花了很多时间试图找出问题所在,我确实打算学习 jQuery,但现在我只是想让它工作,所以请不要告诉我使用 jQuery,
编辑:截图链接:
我的浏览器是 Safari 7.0.4,我试过 Firefox 也遇到了同样的问题。
【问题讨论】:
-
您是否遇到任何错误?如果您收到任何错误消息,我们可以查看您收到的错误消息吗?
-
"我唯一的问题是我在 html 表格中显示的搜索结果出现在页面顶部的所有内容之上,"??
-
我没有收到任何错误消息,这是图片链接,我无法上传,因为我的代表不够高。i.imgur.com/EJKhaTi.png
-
您的 JavaScript 代码乍一看似乎是正确的。但是我在你的 php 代码中检测到了一个 sql 注入漏洞。请使用PDO 或mysql_real_escpace_string
-
谢谢你,Sascha,我知道 mysql_real_escape 字符串,但它在本地托管,永远不会放在公共服务器上,不过为了完整起见,我稍后会添加它。我创建这个网站纯粹是为了了解更多关于 Web 开发的信息。
标签: javascript php mysql ajax innerhtml