我希望你能帮助我。我在搜索表单中创建了一个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"},…]
答案 0 :(得分:1)
您正在迭代商店数组中的每个JSON对象,因此这意味着您应该可以使用' this'来访问每个对象的属性。回调函数中的关键字。试试 -
$.each(data.shops, function() {
console.log(this.username);
}
或者如果您使用索引和对象值的回调方法。
$.each(data.shops, function (index, object) {
console.log(object.username);
});