【发布时间】:2019-01-08 16:30:37
【问题描述】:
我在 Bloodhound 中使用 Typeahead(带有默认建议),到目前为止一切正常。但是,当我尝试动态更改建议的值时,我遇到了一些问题。
例如,当我选择其中一个元素时,我有一组可用的建议,例如 [ "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:selected 事件的那个:
$("#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 ) );
});
但它们都不起作用。有谁知道如何解决这个问题?
【问题讨论】:
-
你能用你的代码解决你的问题吗?
-
真的是
return available_categories.filter( element => !selected_items.includes( element ) );吗?不应该是available_items吗? -
@MM 是的,抱歉。这是一个错字。我将创建一个 jsfiddle 并稍后发布。
-
@IslamElshobokshy 这是小提琴jsfiddle.net/obx3k0qr/8,您可以在下面找到我尝试实现的更详细的版本。
-
@ChristophM。我想出了this,我能够删除从数组中选择的值,但我还不能更新本地,我可能会在星期一看到其余的。到那时你可以尝试处理这个小提琴示例:)
标签: javascript jquery typeahead bloodhound