ОБНОВЛЕНИЕ
Основываясь на правильном ответе @BenSmith (https://stackoverflow.com/users/203371/BenSmith), я смог чтобы найти мою проблему и обнаружил, что я неправильно перемещаюсь по иерархии JSON. Вот рабочий код:
// instantiate the bloodhound suggestion engine
var engine = new Bloodhound({
datumTokenizer: function (datum) {
return Bloodhound.tokenizers.whitespace(datum.title);
},
queryTokenizer: Bloodhound.tokenizers.whitespace,
prefetch: {
url: "SampleData.json",
filter: function (data) {
//console.log("data", data.response.songs)
return $.map(data.response.songs, function (song) {
return {
title: song.title,
artistName: song.artist_name
};
});
}
}
});
// initialize the bloodhound suggestion engine
engine.initialize();
// instantiate the typeahead UI
$('#prefetch .typeahead').typeahead(
{
hint: true,
highlight: true,
minLength: 1
},
{
name: 'engine',
displayKey: 'title',
source: engine.ttAdapter(),
templates: {
empty: [
'<div class="empty-message">',
'unable to find any results that match the current query',
'</div>'
].join('\n'),
suggestion: Handlebars.compile('<p><strong>{{title}}</strong> by {{artistName}}</p>')
}
});
Спасибо @BenSmith за помощь!
Исходный вопрос
Я новичок в работе с Typeahead и Bloodhound. Документация не очень полезна. У меня есть набор объектов JSON, которые я получаю из API, с которым работаю. Я пытаюсь понять, как перемещаться по моим объектам JSON, чтобы Bloodhound мог их понять.
Цель здесь состоит в том, чтобы пользователь начал вводить название песни. Затем автозаполнение отобразит список названий песен и исполнителей, которыми они были исполнены.
Например: Колокольчики в полночь от Mastodon
Я использую последние версии каждой библиотеки: https://twitter.github.io/typeahead.js/
Образец JSON (SampleData.json):
{"response": {"status": {"version": "4.2", "code": 0, "message": "Success"}, "songs": [{"title": "Chimes At Midnight", "artist_name": "Mastodon", "artist_foreign_ids": [{"catalog": "7digital-AU", "foreign_id": "7digital-AU:artist:29785"}, {"catalog": "7digital-UK", "foreign_id": "7digital-UK:artist:29785"}], "tracks": [], "artist_id": "ARMQHX71187B9890D3", "id": "SOKSFNN1463B7E4B1E"}, {"title": "Down Under", "artist_name": "Men at Work", "artist_foreign_ids": [{"catalog": "7digital-AU", "foreign_id": "7digital-AU:artist:50611"}], "tracks": [], "artist_id": "AR4MVC71187B9AEAB3", "id": "SORNNEB133A920BF86"}]}}
Используйте этот сайт http://json.parser.online.fr/, чтобы легко отформатировать JSON.
JSON, который я получу, всегда будет в одном и том же формате, но будет содержать разные данные. В этом примере «дорожки» нулевые. Другие результаты будут иметь данные. Мне также нужно иметь доступ к этим данным.
Я использую последнюю версию JQuery. Вот что я включил в свою html-страницу:
<script src="Scripts/jquery-2.1.1.min.js"></script>
<script src="Scripts/typeahead.bundle.min.js"></script>
Вот HTML:
<div id="prefetch">
<input class="typeahead" type="text" placeholder="Songs...">
</div>
Вот сценарий:
// instantiate the bloodhound suggestion engine
var engine = new Bloodhound({
datumTokenizer: function (d) { return Bloodhound.tokenizers.whitespace(d.tokens.join(' ')); },
queryTokenizer: Bloodhound.tokenizers.whitespace,
prefetch: {
url: "SampleData.json",
filter: function (response) {
return response.engine;
}
}
});
// initialize the bloodhound suggestion engine
engine.initialize();
// instantiate the typeahead UI
$('#prefetch .typeahead').typeahead(
{
hint: true,
highlight: true,
minLength: 1
},
{
name: 'songs',
displayKey: function (engine) {
return engine.songs.artist_name;
},
source: engine.ttAdapter()
});
Когда я пытаюсь запустить этот код, я получаю следующую ошибку:
Uncaught TypeError: Невозможно прочитать маркеры свойства undefined
Любая помощь или направление здесь будет принята с благодарностью. Мне просто нужно знать, как получить данные JSON, с которыми я работаю, работая с Typeahead/Bloodhound.
Спасибо!