Я использую Typeahead (с предложениями по умолчанию) с Bloodhound, и пока все работает нормально. Однако у меня возникают некоторые проблемы, когда я пытаюсь динамически изменить значения предложений.
Например, у меня есть массив доступных предложений, таких как ["A", "B", "C"], когда я выбираю один из этих элементов, он добавляется в поле со списком. Но я хочу убедиться, что каждый элемент выбран только один раз. Вот почему я хочу удалить элемент из списка. Поэтому, если пользователь выбирает элемент «B», список доступных предложений должен выглядеть следующим образом: [«A», «C»].
Вот код, который я пробую:
var available_items = [ "Item 1", "Item 2", ... , "Item N" ];
var my_bloodhound = new Bloodhound(
{
local: available_items,
queryTokenizer: Bloodhound.tokenizers.whitespace,
datumTokenizer: Bloodhound.tokenizers.whitespace
)};
$( "#my-typeahead-field" ).typeahead(
{
minLength: 0,
highlight: true
},
{
name: 'items',
limit: 10,
source: search_function,
});
var f = function( )
{
return available_categories.filter( element => !selected_items.includes( element ) );
}
function search_function( query, sync, async )
{
if( "" === query )
{
sync( f )
}
else
{
my_bloodhound.search( query, sync);
}
}
Обратите внимание, что массив selected_items заполняется, когда пользователь выбирает элемент списка предложений. Я пробую много разных подходов, как это:
http://jsfiddle.net/likeuntomurphy/tvp9Q/
или тот, где я использую typeahead: выбранное событие:
$("#my-typeahead-field").bind('typeahead:select', function( event, item )
{
console.log('Selection: ' + item);
selected_items.push( item );
available_categories = available_categories.filter( element => !selected_items.includes( element ) );
});
Но ни один из них не работает. У кого-нибудь есть идеи, как решить эту проблему?