gpt4 book ai didi

javascript - 如何将复杂的嵌套 json 映射到 jquery 自动完成格式?

转载 作者:行者123 更新时间:2023-12-01 03:53:14 25 4
gpt4 key购买 nike

如何将复杂的嵌套 json 映射到 jquery 自动完成格式?我尝试将自定义 json 映射到所需的 jquery 自动完成格式标签、值...但我的列表是“未定义”。这是我的设置:

JSON:

{"data":[{"DT_RowId":"row_A6J851","accounts":{"code":"A6J851","name":"Peter Jackson"}},{"DT_RowId":"row_1D01Q14","accounts":{"code":"1D01Q14","name":"Earl Bundy"}}]}

Javascript:

$('#input-search').autocomplete({
source: function ( request, response ) {
$.ajax({
type: 'GET',
url: '/source.php',
dataType: "json",
success: function( data ) {
response( $.map( data.data.accounts, function( value, key ) {
return {
label: value.name,
value: value.name,
id: value.code
}
}));
}
});
},
create: function() {
$(this).data('ui-autocomplete')._renderItem = function (ul, item) {
return $( "<li></li>" )
.append( "<a>" + item.label + "</a>" )
.appendTo( ul );
};
}
});

最佳答案

从您的数据示例来看,您似乎没有迭代嵌套的帐户数组,而是迭代数据数组。尝试这样的事情:

$('#input-search').autocomplete({
source: function ( request, response ) {
$.ajax({
type: 'GET',
url: '/source.php',
dataType: "json",
success: function( data ) {
var results = [];
$.each(data.data, function(d){
var mapped = $.map(d.accounts, function( value, key ) {
return {
label: value.name,
value: value.name,
id: value.code
};
})
results = results.concat(mapped);
});
response(results);
}
});
},
create: function() {
$(this).data('ui-autocomplete')._renderItem = function (ul, item) {
return $( "<li>" )
.append( "<span>" + item.label + "</span>" )
.appendTo( ul );
};
}
});

关于javascript - 如何将复杂的嵌套 json 映射到 jquery 自动完成格式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43005228/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com