Typeahead and Bloodhound - how to get JSON result
// instantiate the bloodhound suggestion engine
var countries = new Bloodhound({
datumTokenizer: function(countries) {
return Bloodhound.tokenizers.whitespace(countries.value);
},
queryTokenizer: Bloodhound.tokenizers.whitespace,
remote: {
url: "http://vocab.nic.in/rest.php/country/json",
filter: function(response) {
return response.countries;
}
}
});
// initialize the bloodhound suggestion engine
countries.initialize();
// instantiate the typeahead UI
$('.typeahead').typeahead(
{ hint: true,
highlight: true,
minLength: 1
},
{
name: 'countries',
displayKey: function(countries) {
return countries.country.country_name;
},
source: countries.ttAdapter()
});
Example Codepen
Typeahead Output
Notes:
- data on your server = "prefetch".
- data from outside = "remote"
NOTE: if you do all this and it still is not working examine your data.json file (whatever you have named it)
example of good format: https://github.com/twitter/typeahead.js/blob/gh-pages/data/countries.json
['data1','data2',.....]
I was tripped up on out of place quote.