2

我需要在这个自动完成 jquery ui 脚本中限制结果(最多 10 个)。我知道我必须使用 slice 函数,但我无法将其正确放置在脚本中。在此先感谢您的帮助。

$(document).ready(function() {
    var myArr = [];

    $.ajax({
        type: "GET",
        url: "events.xml", // change to full path of file on server
        dataType: "xml",
        success: parseXml,
        complete: setupAC,
        failure: function(data) {
            alert("XML File could not be found");
            }
    });

    function parseXml(xml)
    {
        //find every query value
        $(xml).find("topevent").each(function()
        {
            //you are going to create an array of objects 
        var thisItem = {}; 
        thisItem['label'] = $(this).attr("label"); 
        thisItem['value'] = $(this).attr("value");
        myArr.push(thisItem); 

        }); 
    }

    function setupAC() {
    $("input#searchBoxEv").autocomplete({
    source: myArr,
    minLength: 3,
    select: function(event, ui) {
    var urlString = "http://mysite.com/" +  "eventi/" + (ui.item.value) + ".html";
    $("input#searchBoxEv").val(urlString);
    location.href=urlString;

                           }
    });
}
}); 
4

2 回答 2

2
$("#auto").autocomplete({
    source: function(request, response) {
        var results = $.ui.autocomplete.filter(myarray, request.term);

        response(results.slice(0, 10));
    }
});

你可以在这里找到更多文档..

http://jqueryui.com/autocomplete/

于 2012-10-18T10:02:00.817 回答
0

最后我解决了在 jquery.ui css 中添加两个参数的问题:最大高度和溢出:隐藏。自动完成初始化为 3° 字母,为了获得更好的结果,人们必须输入更多。它适用于五种不同的浏览器(IE、Chrome、Opera、Firefox、Safari)。

.ui-autocomplete { 位置:绝对;光标:默认;文本对齐:左;最大高度:245px;溢出:隐藏;}

于 2012-10-19T07:33:26.920 回答