首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >这个自动完成脚本有什么问题?

这个自动完成脚本有什么问题?
EN

Stack Overflow用户
提问于 2014-11-29 17:50:46
回答 3查看 94关注 0票数 0

这是我的HTML页面。

代码语言:javascript
运行
复制
<form action="" method="post">
    <input type="text" class="auto" name="search" autocomplete="off">
</form>
<script>
  $(document).ready(function($){
    $('.auto').autocomplete({
    source:'connect.php', 
    minLength:1
    });
});
</script>

这是我的connect.php

代码语言:javascript
运行
复制
if(isset($_GET['term'])) {
  require "db.php";

  $con = mysqli_connect("$host","$user","$password","$db");

  if (mysqli_connect_errno())
    {
    echo "Failed to connect to MySQL: " . mysqli_connect_error();
    }

  $term = mysqli_real_escape_string($con, $_GET['term']);
  $term = strtolower($term);
  $query = "SELECT `name` FROM `products` WHERE `name` LIKE '%$term%'";
  $result = mysqli_query($con, $query);
  $return_array = array();
    while($row = mysqli_fetch_array($result)) {

        $return_array[] = $row;
    }
    echo json_encode($return_array);
}

使用chrome工具检查响应,如下所示:

代码语言:javascript
运行
复制
[{"0":"MacBook Pro 13-inch","name":"MacBook Pro 13-inch"},{"0":"MacBook Pro 15-inch","name":"MacBook Pro 15-inch"},{"0":"MacBook Air 13-inch","name":"MacBook Air 13-inch"},{"0":"MacBook Air 11-inch","name":"MacBook Air 11-inch"},{"0":"iMac 21.5-inch","name":"iMac 21.5-inch"},{"0":"iMac 27-inch","name":"iMac 27-inch"},{"0":"Mac Pro Quad-Core","name":"Mac Pro Quad-Core"},{"0":"Mac Pro 6-Core","name":"Mac Pro 6-Core"}]

但是在页面上,我得到了“没有搜索结果”。

我在谷歌上搜索了很多,我认为这与json的输出方式有关,但我不确定。我不希望使用ajax方法。

请不要PDO,因为我只能理解基本的程序代码。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-11-29 18:40:29

正如rodrigogq已经指出的,jQuery UI自动完成以两种形式接受数据,

要么是一个字符串数组:

代码语言:javascript
运行
复制
[ "value1", "value2" ]

或具有label和value属性的对象数组:

代码语言:javascript
运行
复制
[  { label:"value1", value:0},  { label:"value2", value:1}, ]

您有两个选项:修改服务器端脚本以提供适当的响应,

修改客户端脚本以净化服务器响应。

以下是根据您所分享的答复,后面的内容:

代码语言:javascript
运行
复制
$(document).ready(function($){
  $('.auto').autocomplete({
    source: function(request, response) {
      $.get('connect.php', { term: request.term }, function(data) {
        var matches = $.map($.parseJSON(data),function(obj){
          return obj.name;
        });
        response(matches);
      });
    }, 
    minLength:1
  });
});
票数 1
EN

Stack Overflow用户

发布于 2014-11-29 17:59:06

$(document).ready(function($){是什么意思?应该是$(document).ready(function(){ (注意$)。

另外,尝试将完整的url发送到您的source选项,比如http://www.yoursite.com/connect.php

编辑

还请阅读以下内容:http://api.jqueryui.com/autocomplete/#option-source

正如您所看到的,您可以将数组提供为:

代码语言:javascript
运行
复制
   [ "value1", "value2" ]

或者:

代码语言:javascript
运行
复制
   [  { label:"value1", value:0},  { label:"value2", value:1}, ]
票数 0
EN

Stack Overflow用户

发布于 2014-11-29 18:33:15

为了让您知道出了什么问题:代码:

代码语言:javascript
运行
复制
$(document).ready(function(){
    $('.auto').autocomplete({
        source:'test1.php',
        minLength:1
    });
});

这个虚拟PHP文件test1.php:

代码语言:javascript
运行
复制
echo json_encode(array('alpha', 'alphabet', 'beta'));

自动完成正在工作。所以,你必须改变:

代码语言:javascript
运行
复制
   while($row = mysqli_fetch_array($result)) {
        $return_array[] = $row;
    }
    echo json_encode($return_array);

转入:

代码语言:javascript
运行
复制
   while($row = mysqli_fetch_array($result, MYSQLI_ASSOC)) {
        $return_array[] = $row['name'];
    }
    echo json_encode($return_array);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27205163

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档