Атрибуты арии не добавляются к результатам

Я использую select 2 версии 4.0.2 и создал select для поиска удаленных данных через ajax.

Я получаю данные в порядке, но когда результаты отображаются, атрибут aria-selected не добавляется, и поэтому я не могу выбрать ни один из параметров.

Я считаю, что это может быть связано с templateResult и templateSelection, но я не знаю, что нужно изменить.

Jquery:

$("#select2").select2({
  theme: "bootstrap",
  ajax: {
    url: "/search/games",
    dataType: 'json',
    delay: 250,
    data: function (params) {
      return {
        q: params.term, // search term
        type: "suggest"
      };
    },
    processResults: function (data, params) {
      return {
        results: data.games,
      };
    },
    cache: true
  },
  escapeMarkup: function (markup) { return markup; },
  minimumInputLength: 3,
  templateResult: formatResult,
  templateSelection: formatSelection
});

function formatResult(game) {
  markup = "<p>" + game.name + "</p>";
  return markup;
};

function formatSelection(game) {
  markup = "<p>" + game.name + "</p>";
  return markup;
}

Форма:

= form_for [:member,@event], :html => {:class => "formtastic form-horizontal"} do |f|
  %fieldset
    %div{:class => "control-group"}
      = f.label :game_id, :class => "control-label"
      %div{:class => "controls"}
        = f.select :game_id, "", {}, :class => "form-control"

person Ross Mills    schedule 20.01.2016    source источник


Ответы (1)


Оказывается, при обработке результатов данные должны быть сопоставлены с идентификатором и текстовым атрибутом, чтобы их можно было распознать:

processResults: function (data, params) {
  return {
    results: jQuery.map( data.games, function( game ) {
      var arr = {id:game.name,text:game.name};
      return arr;
    }),
  };
}
person Ross Mills    schedule 20.01.2016