jquery - 简单的 jquery UI 自动完成页面不起作用

标签 jquery json jquery-ui autocomplete

我是 jquery 编程的初学者:如果我的代码不好,我深表歉意。

我有一个简单的 html 文件

<!DOCTYPE html>
<html>
<head>
 <link href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8/themes/base/jquery-ui.css" rel="stylesheet" type="text/css"/>
  <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5/jquery.min.js"></script>
  <script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8/jquery-ui.min.js"></script>

 <script>
$(document).ready(function() {
    var arr = [];
    var items = {};
    $.getJSON('testjson.json', function(data) {
        $.each(data, function(key, value){
            arr.push(value);
        });
        arr.join(',');
        items = {source: arr};
    });
    $("input#autocomplete").autocomplete(items);
  });
  </script>
</head>
<body style="font-size:62.5%;">

<div id="Heading" >
<h2 align="center">Client Browser</h2>
</div>  
<input id="autocomplete" size="100" align="middle"/>

</body>
</html>

这是我的 testjson.json 文件:

{
"1":"One",
"2":"Two",
"3":"Three"
}

当我使用 Altova XML spy 运行 html 文件时,我得到了正确的输出。但是当我在浏览器中打开它(通过 XAMP 服务器运行)时,这就是我在 Firefox 控制台中得到的内容:

jquery-ui.min.js 第 5 行中的“this.source 不是函数”

但是,如果我直接将 JS 对象传递给自动完成函数,它确实可以工作,例如,以下代码可以工作:

$("input#autocomplete").autocomplete({source:["One", "Two", "Three"]});

我无法理解问题出在哪里,因为项目包含相同的对象。我在这里做错了什么?

最佳答案

我认为问题在于您不是在成功的 Ajax 请求之后而是在执行请求的同时初始化自动完成功能。

您应该将相应的行放在成功处理程序中:

$.getJSON('testjson.json', function(data) {
    $.each(data, function(key, value){
        arr.push(value);
    });
    arr.join(',');               // BTW, this line doesn't make any sense
    items = {source: arr};

    $("input#autocomplete").autocomplete(items);   // <-- place here
});

关于jquery - 简单的 jquery UI 自动完成页面不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11024300/

相关文章:

javascript - 从文档就绪外部调用时未定义函数

java - java.lang.String 类型的值包无法转换为 JSONArray

javascript - 是否可以在变量上调用 jquery 函数?

jquery - 检测 jQuery UI slider 何时移动?

javascript - 如何设置在 Highcharts/Highstock 中绘制图表时选择的默认范围

jQuery - 仅选择具有特定类父级的图像的属性值

javascript - 如何使用 jQuery 获取数组,多个 &lt;input&gt; 具有相同的名称

json - 通过 RestTemplate 将 POST 和 PUT 发送到 Spring Data Rest Api

javascript - 可以是 String 或 Boolean 的 Spring 和 Json 字段映射

单击外部时 JQuery 自动完成关闭选项