Моя инициализация twiter typeahead:
var cityList = new Bloodhound({
datumTokenizer: Bloodhound.tokenizers.obj.whitespace('value'),
queryTokenizer: Bloodhound.tokenizers.whitespace,
remote: {
url: $('#citySearchInput').attr('data-src')+'?query=%QUERY',
wildcard: '%QUERY',
dataType: "json",
ajax : {
type: "GET"
}
}
});
$('#citySearchInput').typeahead({
minLength: 2,
highlight: true,
hint: true
}, {
display: 'value',
source: cityList,
limit:25,
valueKey: 'query',
templates: {
empty: function(data){
console.log(data);
return 'empty';
},
suggestion: function(data) {
console.log(data);
return '<p><a href="'+data.link +'">' + data.value + '</a></p>';
}
}
});
Это работа с ответом от бэкэнда как:
[{"link":"\/en\/forecast\/Iran\/Ostan-e-Lorestan\/Defkandar","value":"Defk\u0101ndar, Ost\u0101n-e Lorest\u0101n(Iran)"},{"link":"\/en\/forecast\/Iran\/Ostan-e-Lorestan\/Defkundar","value":"Defk\u016bndar, Ost\u0101n-e Lorest\u0101n(Iran)"}]
Но когда возвращается больше данных, например 8 элементов - всегда пишите "пусто" и в данных предложения 0. Я исправил это после установки лимита в js с 25 до 100, но я не думаю, что это правильный путь.