0

在引导程序 2 中,我使用以下代码发布了一个 json 对象,

$('#typeahead').typeahead({
        source: function (query, process) {
         var URL = 'http://localhost:8080/autocomplete/search/';
         var query = {"t:jsonStringField": {
                          "name": "model",
                          "value": "fusion"
                         },
                      "t:jsonStringFilter": [
                             {"name": "year","value": "2009"},
                             {"name": "make","value": "ford"}
                         ]
                      }; 

            return $.getJSON(URL,
                { query: JSON.stringify(query)},
                function (data) {
                    return process(data);
                });
        }
    });

现在在 twitter tyeahead 0.9.3 中,他们已经取消了源概念并转移到了远程概念,但不幸的是我不知道如何使用它。

$(".typeahead").typeahead({

     remote : {    
      url: 'http://localhost:8080/autocomplete/search/',

      replace: function(uri, query) {

         var query = {"t:jsonStringField": {
                          "name": "model",
                          "value": "fusion"
                         },
                      "t:jsonStringFilter": [
                             {"name": "year","value": "2009"},
                             {"name": "make","value": "ford"}
                         ]
                      }; 

         return uri + JSON.stringify(query);
      },

      filter: function(response) {
           return response.matches;
      }

      return process(resultList);

    }
 }

不幸的是它不起作用,我如何发布 JSON 对象而不是将其附加到字符串?谢谢。

4

1 回答 1

1

在您的原始代码中,您使用 $.getJSON。这会将请求(并期望 json 作为结果)发送到:http://localhost:8080/autocomplete/search/?query=%7B%22t%3AjsonStringField%22%3A%7B%22name%22%3A%22model%22%2C%22value%22%3A%22fusion%22%7D%2C%22t%3AjsonStringFilter%22%3A%5B%7B%22name%22%3A%22year%22%2C%22value%22%3A%222009%22%7D%2C%7B%22name%22%3A%22make%22%2C%22value%22%3A%22ford%22%7D%5D%7D

要对 Twitter 的 Typeahead 执行相同操作,调用远程数据的替换函数应该返回一个有效的 url。在您的函数中?query=,缺少 url 的一部分。

您必须设置: url:'http://localhost:8080/autocomplete/search/?query=',

您可能还必须对您的 json 输入进行 urlencode。

注意:您不需要该行return process(resultList);您将必须使用过滤器功能将您的 json 结果转换为有效数据:

组成数据集的各个单元称为基准。数据的规范形式是具有值属性和标记属性的对象。

您可以使用模板来设置下拉结果的样式,请参阅:http: //twitter.github.io/typeahead.js/examples/

默认情况下,由 typeahead.js 创建的下拉菜单看起来很难看,您需要对其进行样式设置以确保它适合您的网页主题。

您将需要来自https://github.com/jharding/typeahead.js-bootstrap.css的额外 CSS 来设置 Bootstrap 的默认下拉菜单样式。

于 2013-09-12T20:18:37.223 回答