你好,我坐在这里思考以下问题:
我有一个自动建议搜索引擎,它通过如下表格运行:
zipcode city sum
12345 town 5
我确实通过使用 javascript 来实现搜索,该 javascript 在将输入的每个字母上运行一个循环。到目前为止,我只能寻找一个可以是城市名称或邮政编码的关键字。
现在我想将这两者结合起来,这样我就不再将用户限制为这两者之一,即使在输入城市和邮政编码时也会找到它。
因此,我想使用以下方法分隔每个关键字:
preg_split('/[\s]+/', $keywords);
这是目前的问题。使用这种方法,每个关键字都将被插入到一个数组中。这个怎么运作:
在 html 中我有一个输入字段。下面我有一个无序列表 div。在那个 div 中,javascript 会自动添加我的 search.php 文件中的结果。看起来像:
include('../scripts/db_connect.php');
if (isset($_POST['search_term']) == true && empty($_POST['search_term']) == false) {
$search_term = $db->real_escape_string(htmlentities(trim($_POST['search_term'])));
$search_term_query = "SELECT * FROM `a` WHERE `b` LIKE '$search_term%'";
if ($result_query = $db->query($search_term_query)) {
while ($row = $result_query->fetch_assoc()) {
echo '<li>',
$row["a"],
' ',
$row["b"],
' ',
'( ',
$row["c"],
' )',
' </li>';
}
}
}
我的 javascript 只处理一个关键字:
$(document).ready(function() {
$('.searchfield').keyup(function() {
var search_term = $(this).attr('value');
$.post('ajax/search.php', {search_term:search_term}, function(data) {
$('.result').html(data);
$('.result li').click(function() {
var result_value = $(this).text();
$('.searchfield').attr('value', result_value);
$('.result').html('');
});
});
});
});
所以目前我不知道如何解决这个问题。如果有人可以帮助我,我真的很感激。谢谢。