0

この jsfiddleで select2実装が機能しています。Github リポジトリの検索を有効にし、ユーザーが選択できるように結果を返します。特定の検索に一致するリポジトリが 1 つだけの場合、そのリポジトリが自動的に選択されます。

select2 フォームにいくつかのデフォルト オプションを事前入力できるようにする必要があります。ドキュメントに記載されているように、次のようなことができるはずです。

<select id='select2_element' multiple='multiple' style='width:100%;'>
  <option value="easypr-ja" selected="selected">EasyPR-Java 70 32393764</option>
</select>

ボタンを押すと、事前に入力されたリポジトリconsole.log all selected dataの と にアクセスできることがわかりますが、ブラウザーでは、上記の事前入力されたオプションが として表示されます。idtextundefined undefined easypr-ja

デフォルトオプションの値を正しく表示するにはどうすればよいですか?

ここに示すように、私の実装はいくつかのカスタムフォーマットを行っています:

var createRepo, formatRepo, formatRepoSelection, selectRepos;

formatRepoSelection = function(element) {
  return element.name + ' ' + element.forks + ' ' + element.id;
};

formatRepo = function(element) {
  var markup;
  if (!element.loading) {
    return markup = element.name + ' ' + element.id;
  }
};

createRepo = function() {
  $(".btn-create-repos").off("click");
  return $(".btn-create-repos").click(function(e) {
    var el, element_ids;
    el = $(e.currentTarget);
    element_ids = $("#select2_element").select2('data');
    return console.log(element_ids);
  });
};

selectRepos = function() {
  var option, select2_element;
  select2_element = $('#select2_element');
  select2_element.select2({
    placeholder: "Type in 'easypr-ja' to get only 1 result",
    ajax: {
      url: "https://api.github.com/search/repositories",
      dataType: 'json',
      delay: 250,
      data: function (params) {
        return {
          q: params.term,
          page: params.page
        };
      },
      processResults: function (data, params) {

        if (data.items.length === 1) {
          setTimeout(function() {
              $("#select2-select2_element-results li:first-child").trigger('mouseup');
          }, 0);
          return {
            results: data.items
          };
        } else {
          params.page = params.page || 1;

          return {
            results: data.items,
            pagination: {
              more: (params.page * 30) < data.total_count
            }
          };
        }
      },
      cache: true
    },

    escapeMarkup: function(markup) {
      return markup;
    },
    minimumInputLength: 2,
    templateResult: formatRepo,
    templateSelection: formatRepoSelection
  });
};

$(function() {
  selectRepos();
  return createRepo();
});
4

1 に答える 1

0

以下の例に従って form_for を使用してください。参考になるかもしれません

<%= f.select(:categories, Category.all.collect {|c| [c.name, c.id]}, {}, id: "event_categories", :multiple => true) %>

<script type="text/javascript">
    $("#event_categories").select2();
    <% if @event.id.present?%>
        $("#event_categories").val(<%= @event.categories.collect(&:id)%>).change()
    <% elsif params[:action]=="create" || params[:action]=="update" %>
        $("#event_categories").val(<%=params[:event][:categories].map(&:to_i).drop(1)%>).change()
    <% end %>
</script>
于 2016-08-17T08:08:51.623 に答える