我需要使用组合框执行以下操作。
Select box
有一个用户可以搜索的默认城市列表。- 如果用户在
input
框中输入文本,我需要进行 ajax 调用来获取数据并向用户显示选项。 - 如果根据用户请求获取数据,则应将这些城市附加到
Select box
使用jQuery 自动完成功能,我可以在用户输入字符串并显示结果时获取 json 数据。但是,我对如何使用组合框集成它一无所知。
Combobox使用静态数据数组进行搜索,如果我理解正确,则使用正则表达式来匹配值。但是,如何中断它并使用 ajax 调用从服务器获取数据并更新结果?
输入文本框的自动完成:
$( "#searchDestination" ).autocomplete({
delay: 500,
source: function( request, response ) {
$.ajax({
url: "/wah/destinationsJson.action",
dataType: "json",
data: {
term: request.term
},
type: "POST",
success: function(data){
if(data.cities.length == 0)
return response(["No matching cities found for " + request.term]);
response( $.map(data.cities, function(item){
return{
label: item.name,
value: item.name
};
})
);
}
});
},
minLength: 2
});
});