我有一个MySQL数据库表作为用户。
我使用php和ajax填充html表。(工作正常)
但我想搜索特定的数据,也写了一些代码,但没有得到我的错误。
我的index.html
<body>
<div class="container">
<h3>Product List</h3>
<div id="users-grid">
</div>
</div>
</body>
<script>
function getresult(url) {
$.ajax({
url: url,
type: "POST",
success: function(data){ $("#users-grid").html(data);}
});
}
getresult("getresult.php");
</script>
我的getresult.php(用于填充#users-grid)
<?php
include 'database.php';
$pdo = Database::connect();
$product = "";
$queryCondition = "";
?>
<form name="frmSearch" method="post" action="index.php">
<div class="search-box">
<p>
<input type="text" placeholder="Product Name" name="product" value="<?php echo $product; ?>" />
<input type="button" name="go" class="btnSearch" value="Search" onclick="getresult('getresult.php')">
<input type="reset" class="btnSearch" value="Reset" onclick="window.location='index.php'"></p>
</div>
<table class="table table-striped table-bordered" class="tablesorter">
<thead>
<tr>
<th>Date</th>
<th>Product</th>
<th>Quantity</th>
<th>Gross Price</th>
<th>Profit</th>
</tr>
</thead>
<tbody>
<?php
$queryCondition = "";
if(!empty($_POST["product"])) {
$queryCondition .= " WHERE product LIKE '" . $_POST["product"] . "%'";
}
$orderby = " ORDER BY id desc";
$sql = "SELECT * FROM users " . $queryCondition . $orderby;
foreach ($pdo->query($sql) as $row) {
echo '<tr>';
echo '<td>'. $row['date'] . '</td>';
echo '<td>'. $row['product'] . '</td>';
echo '<td>'. $row['quantity'] . '</td>';
echo '<td>'. $row['grossprice'] . '</td>';
echo '<td>'. $row['profit'] . '</td>';
echo '</tr>';
}
Database::disconnect();
?>
</tbody>
</table>
</form>
谢谢
答案 0 :(得分:0)
此代码将搜索以搜索查询开头的任何内容
$queryCondition .= " WHERE product LIKE '" . $_POST["product"] . "%'";
我认为您应该将其更改为具有完整搜索功能
$queryCondition .= " WHERE product LIKE '%" . $_POST["product"] . "%'";
当您点击提交按钮时,只有当用户点击按钮时才会触发,但是当用户在文本上输入内容并按回车键时,它将提交您的表单,因此您必须将代码更改为
<form name="frmSearch" method="post" onsubmit="return getresult('getresult.php')">
<div class="search-box">
<input type="text" placeholder="Product Name" name="product" value="<?php if(isset($_POST["product"])) echo $_POST["product"]; ?>" />
<input type="button" name="go" class="btnSearch" value="Search">
<input type="reset" class="btnSearch" value="Reset" onclick="window.location='index.php'">
</div>
</form>
我更改了输入值以显示您的搜索查询。返回部分用于停止页面重新加载
要发送POST数据,您必须将ajax代码更改为
function getresult(url) {
$.ajax({
url: url,
type: "POST",
data: {product: $('input[name=product]').val()},
success: function(data){ $("#users-grid").html(data);}
});
return false
}