jQuery UI自动完成功能不起作用

时间:2011-03-30 07:11:00

标签: javascript jquery json jquery-ui jquery-ui-autocomplete

这是我的JavaScript代码:

<script type="text/javascript">
//<![CDATA[
$(document).ready(function() {
    $("input#suggestZams").autocomplete({
        source: "content/prevadzky/zam/zam_json2.php?letter=all",
        minLength: 1,
        delay: 0,
        select: function(event, ui) {
            alert(1);
        }
    });
});
//]]>
</script>

这是我的HTML:

<input id="suggestZams" class="input" size="10" />

网址zam_json2.php?letter=all返回此json:

[
{ "id": "31440", "value": "Andrej\u010d\u00e1k, Ing." },
{ "id": "31690", "value": "Alexovi\u010d , Ing." },
{ "id": "31796", "value": "Antoni\u010d , Ing." },
{ "id": "31989", "value": "Antolik , Ing." },
{ "id": "32010", "value": "Ambrozov\u00e1 RNDr., PhD." },
{ "id": "32014", "value": "Aksam\u00edt" },
{ "id": "32024", "value": "Angelovi\u010d" },
{ "id": "32102", "value": "Andrej\u010d\u00e1k" },
{ "id": "32168", "value": "Avukov\u00e1 , Ing." },
{ "id": "32177", "value": "Andr\u00e1\u0161" },
{ "id": "32181", "value": "Andrej\u010d\u00e1kov\u00e1 , Mgr." },
{ "id": "32403", "value": "Arend\u00e1\u0161 , Bc." },
{ "id": "47379", "value": "An\u010fal" },
{ "id": "47399", "value": "Adam\u00edk , Ing." },
{ "id": "50022", "value": "Abo\u0161i" },
{ "id": "50085", "value": "Armer\u00eda Olmedo , Ing." },
{ "id": "53468", "value": "Anto\u0161" },
{ "id": "54837", "value": "Adamec , Ing." },
{ "id": "56659", "value": "Apostolou" },
{ "id": "57820", "value": "Alez\u00e1r" },
{ "id": "58576", "value": "Andrej\u010d\u00e1k , Bc." },
{ "id": "58587", "value": "Aronov\u00e1 , Ing." },
{ "id": "58595", "value": "Abaffy , Bc." },
{ "id": "58607", "value": "Adamec , Bc." },
{ "id": "58643", "value": "Antu\u0161 , Ing." },
{ "id": "62277", "value": "Adam\u010d\u00e1k , Mgr." },
{ "id": "62379", "value": "Andruch" },
{ "id": "63415", "value": "Adamkovi\u010d , Ing." }
]

3 个答案:

答案 0 :(得分:4)

引用:

  

可以自定义自动填充功能   通过各种数据源   指定源选项。一个数据   来源可以是:

     
      
  • 包含本地数据的数组
  •   
  • 一个String,指定一个URL
  •   
  • a Callback
  •   
     

当使用String时,   自动完成插件需要这样   string指向一个URL资源   将返回JSON数据。它可以开启   相同的主机或不同的主机   (必须提供JSONP)。请求   参数“term”被添加到那个   URL。数据本身可以在   与本地数据格式相同   如上所述。

你在做什么对我来说很奇怪。我认为您实际上需要编辑服务器端脚本,以便它期望查询字符串变量term而不是字母返回字符串数组或{{1}的数组}对象而不是{value,id}。

如果网址{label, value}一次性提供“完整”字词列表,您可以按照以下方式执行操作:

content/prevadzky/zam/zam_json2.php?letter=all

答案 1 :(得分:2)

如果要从网址获取数据,则必须为源定义一个函数:

source: function( request, response ) {
    $.ajax({url: "content/prevadzky/zam/zam_json2.php?letter=all",
            dataType: "json",
            ...
           });
    },
...

修改

在文档中说:source可以是一个网址。在这种情况下,尝试更改JSON响应,使其在返回的对象中具有'label'而不是'id'

答案 2 :(得分:1)

这是一个在jQuery 1.5.1中为我工作的脚本。

source: function( request, response ) {
    $.ajax({
        url: "...",
        dataType: "json",
        ...
        success: function( data ) {
            # data = json response
        }
    });
}