无论您输入什么内容,jquery autocomplete都会显示来自源的所有结果,即使它们在输入字段中不包含任何字符。无论我写什么,jQuery自动完成都会返回所有结果(json)
代码如下。
$('input#project-name').autocomplete({
source: "project-list.php",
minLength: 2,
autoFocus: true
});
而源输出json像这样。
[{"value":"sdf"},{"value":"asdas"},{"value":"ANOTHERONE"}]
我已经搜索了一段时间了,但我无法弄清楚我做错了什么。任何帮助是极大的赞赏!
更新
感谢您的答复家伙,但我怕我没有得到它,对不起。我刚刚开始学习这些东西。我的PHP目前看起来像这样。
$userID = $_SESSION['userID'];
$loggedIn = $mysqli->query("SELECT * FROM users WHERE userID = '".$userID."'");
$getRow = "SELECT * FROM projects WHERE projectUserID = '".$userID."'";
if ($loggedIn->num_rows) { // if user is logged in
$projects = array();
if ($result = $mysqli->query("SELECT projectName FROM projects WHERE projectUserID = '".$userID."'")) {
$placeholder = array();
while($row = $result->fetch_object()) {
$placeholder = $row;
array_push($projects, $placeholder);
}
$json = json_encode($projects);
$result = str_replace("projectName", "value", $json);
echo $result;
}
}
但据我所知,我需要包括在那里的术语?我能举个例子吗?
更新2
if (!isset($_REQUEST['term']))
exit;
$projects = array();
if ($result = $mysqli->query("SELECT projectName FROM projects WHERE projectName = '".$mysqli->real_escape_string($_REQUEST["term"])."'")) {
,现在它不返回所有。事实上,它会返回正确的,但只有在完全拼出后才能达到目的。
我相信当你使用一个url源代码时,源代码可以过滤结果。 – cadrell0