我正在使用带有 ASP.NET 文本框的 JQuery UI 自动完成来填充标签和值。这是我从 ajax 调用映射数据的地方:
success: function (data) {
response($.map(data, function (item) {
return {
label: item.label,
value: item.value
}
}));
}
标签是文本,值是用于标识该行的数字。我的问题是当用户选择一个选项时,文本框会用值替换标签。因此,如果他们选择“John Smith”,则文本框会从“John Smith”变为“1234”等。如何操纵选择事件以将文本留在文本框中?任何帮助表示赞赏。谢谢!
这是我的 aspx 页面的更完整视图:
<div class="ui-widget">
<asp:TextBox ID="txbSearchKeyword" runat="server" Columns="50" />
</div>
<asp:HiddenField ID="selectedRecordId" runat="server" />
和jQuery:
(function () {
$("#txbSearchKeyword").autocomplete
({
source:
function (request, response) {
$.ajax({
type: "POST",
url: "AutoComplete.asmx/GetAutoCompleteList",
contentType: "application/json; charset=utf-8",
data: JSON.stringify({ keywordStartsWith: request.term }),
dataType: "json",
success: function (data) {
response($.map(data.d, function (item) {
return {
label: item.label,
value: item.value
}
}));
}
});
},
minLength: 2
});
$("#txbSearchKeyword").autocomplete
({
select: function (event, ui) {
$('#selectedRecordId').val(ui.item.value);
DoSomethingwithdataAJAXfunction(ui.item.value);
}
});
})();