如何显示jQuery自动完成响应并选择它?

时间:2015-02-17 02:31:17

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

我希望你能帮助我。我在搜索表单中创建了一个Ajax自动完成功能。我可以得到响应数组。但我很难在UI中显示它。我只能得到“未定义”这个词。我想要的是执行Ajax自动完成,然后用户可以从建议中进行选择。

到目前为止,这是我的代码。

$("#search-shop-input").autocomplete({

    source: function(request, response) {

         $.ajax({
            url: 'index.php?route=seller/seller/getSellerNames',
            dataType: 'json',
            type: 'post',
            data: { keyword: request },
            success: function(data) {

                var d = '';

                $.each(data.shops, function(key,value) {

                   $.each(value, function(k,v) {
                        console.log(k + ":" + v); //want to get username only
                   });

                });

                //response(d);

            }
        });

    },

    select: function(event, ui) {
        $("#seller_list").val(ui.item.label);
        return false;
    },

    autoFocus: true,
    min_length: 0
});

示例输出:

shops: [{user_id: "162", username: "F_Francium_1"}, {user_id: "163", username: "F_Francium_2"},…]

1 个答案:

答案 0 :(得分:1)

您正在迭代商店数组中的每个JSON对象,因此这意味着您应该可以使用' this'来访问每个对象的属性。回调函数中的关键字。试试 -

$.each(data.shops, function() {
    console.log(this.username);
} 

或者如果您使用索引和对象值的回调方法。

$.each(data.shops, function (index, object) {
    console.log(object.username);
});