我正在尝试使用自定义下拉菜单实现jQuery自动完成功能。我能够使用data()._ renderItem方法(注释掉)自定义菜单项,但这会禁用菜单“选择”功能。如果我尝试通过“标签”字段自定义菜单项“选择”功能有效但我的菜单项HTML被解释为字符串。任何人都可以提出一个干净的方法来实现这一目标。
$("input#selectedInput")
.bind("autocompleteselect", function (event, ui) {
alert("Sel item " + JSON.stringify(ui.item.json));
})
.autocomplete({
appendTo: "#list",
source: function (request, response) {
//alert("success");
$.ajax({
//url: "http://itunes.apple.com/search?term=jack+johnson&entity=musicTrack",
url: "Example REST URL",
dataType: "jsonp",
data: {
featureClass: "P",
style: "full",
maxRows: 12,
name_startsWith: request.term
},
success: function (data) {
response($.map(data.results, function (item) {
itunesJson = item;
return {
label: "<li><img src='" + item.artworkUrl30 + "' alt='no photo'/>" + item.trackName + "</li>",
}
}));
},
});
}
})
/*
.data( "autocomplete" )._renderItem = function( ul, item ) {
return $( "<li></li>" )
.data( "item.autocomplete", item )
.append("<img src='"+item.value+"' alt='no photo'/>"+ item.label)
.appendTo( ul );
};
*/
答案 0 :(得分:0)
请尝试阅读:http://www.devbridge.com/projects/autocomplete/jquery/。 这是我在需要自动完成时使用的内容。它配置起来非常简单。 请告诉我,如果它不符合您的需求。
答案 1 :(得分:0)
答案 2 :(得分:0)
尝试在返回html中将锚标记放在图像周围,例如。 ...
.data( "autocomplete" )._renderItem = function( ul, item ) {
return $( "<li></li>" )
.data( "item.autocomplete", item )
.append("<a><img src='"+item.value+"' alt='no photo'/></a>"+ item.label)
.appendTo( ul );