Я нашел ответ (часть этого, мне все еще нужно работать над этим).Сначала я опубликую код, а затем объясню его:
$(function ()
{
var names = [
{ label: 'Java', value: '1' },
{ label: 'C++', value: '2' },
{ label: 'C#', value: '3' },
{ label: 'Jquery', value: '4' },
{ label: 'Javascript', value: '5' },
{ label: 'ASP', value: '6' },
{ label: 'Pearl', value: '7' },
{ label: 'VB', value: '8' },
{ label: 'Ajax', value: '9' },
{ label: 'Json', value: '10' }];
$("#txtName").autocomplete({
minLength: 2,
source: names,
delay: 500
}).data("autocomplete")._renderItem = function (ul, item)
{
//add data to my control, need to take care of earasing each time.
var elOptNew = document.createElement('option');
elOptNew.text = item.label;
elOptNew.value = item.value;
lst.add(elOptNew);
//this code here adds the items to the popup thats built in.(it's written in jquery-ui.min.js)
return $("<li></li>")
.data("item.autocomplete", item)
.append("<a>" + item.label + "</a>")
.appendTo(ul);
};
});
HTML:
<input id="txtName"/>
<select id="lst" size='10'></select>
Добавленная часть (_renderItem
) добавляет один элемент каждый раз, так что вы можете сделатьвсе, что вы хотите сделать с элементом.Я решил добавить его в список.
Еще одна вещь, которая не была сделана, это стирать список каждый раз.Мне все еще нужно выяснить, как это сделать.