Авто-заполнение с Twitter Typeahead.js (key value)

Возникла задача получить id при поиске необходимой строки с помощью typeahead.js

Тут документация и примеры.

В примере мы видим массив без id:

var states = ['Alabama', 'Alaska', 'Arizona', 'Arkansas', 'California',
 'Colorado', 'Connecticut', 'Delaware', 'Florida', 'Georgia', 'Hawaii',
 'Idaho', 'Illinois', 'Indiana', 'Iowa', 'Kansas', 'Kentucky', 'Louisiana',
 'Maine', 'Maryland', 'Massachusetts', 'Michigan', 'Minnesota',
 'Mississippi', 'Missouri', 'Montana', 'Nebraska', 'Nevada', 'New Hampshire',
 'New Jersey', 'New Mexico', 'New York', 'North Carolina', 'North Dakota',
 'Ohio', 'Oklahoma', 'Oregon', 'Pennsylvania', 'Rhode Island',
 'South Carolina', 'South Dakota', 'Tennessee', 'Texas', 'Utah', 'Vermont',
 'Virginia', 'Washington', 'West Virginia', 'Wisconsin', 'Wyoming'
];

Но нам например надо:

var states = [
 21: 'Alabama', 
 22: 'Alaska',
 23: 'Arizona'
];

Чтобы id элемента в дальнейшем использовать.

Ну и в общем решение задачи:

var substringMatcher = function(strs) {
  return function findMatches(q, cb) {
    var matches, substringRegex;

    // an array that will be populated with substring matches
    matches = [];

    // regex used to determine if a string contains the substring `q`
    substrRegex = new RegExp(q, 'i');

    // iterate through the pool of strings and for any string that
    // contains the substring `q`, add it to the `matches` array
    $.each(strs, function(i, str) {
      if (substrRegex.test(str)) {
        //matches.push(str);
        matches.push({id: i, name: str});
      }
    });
    cb(matches);
  };
};

var $selStates = $('input#sel_states');
$selStates.typeahead({
  hint: true,
  highlight: true,
  minLength: 1
},
{
  name: 'states',
  display: 'name',
  source: substringMatcher(states)
});

$selStates.on('typeahead:select', function(ev, suggestion){
  $('#id_state').val(suggestion.id);
  //console.log(suggestion);
});

Трекбэк с Вашего сайта.

  • Оставить комментарий