当前,select2仅在用户开始输入后才加载数据。我想用一些默认值预加载下拉列表,因此一旦用户单击下拉列表,便已经有一些值可供选择。。我看过文档,但找不到任何内容。有人知道是否有解决方法或我可以做些什么来实现这一目标。

谢谢

编辑:

$('#search-paint').select2({
                placeholder: "Search By:Manufacturer, Color Name, Color Code",
                ajax: {
                    url: "/item/searchPaint",
                    dataType: "json",
                    delay: 250,
                    data: function (params) {
                        return {
                            q: params.term,
                            SprayType: $('#spray-type').val(),
                            page: params.page
                        };
                    },
                    processResults: function (data, params) {
                        params.page = params.page || 1;
                        return {
                            results: data.items.data,
                            pagination: {
                                more: (data.items.current_page * data.items.per_page) < data.items.total
                            }
                        };
                    },
                    cache: true
                },
                escapeMarkup: function (markup) {
                    return markup;
                },
                minimumInputLength: 1,
                templateResult: formatRepo,
                templateSelection: formatRepoSelection
            });

我尝试使用data设置预加载数据,但它仅加载第一个对象,并调用select方法。我也尝试过initSelection,但后来我发现它的用途与我要实现的目的不同。

最佳答案

你可以做这样的事情

var data = [];
$('#search-paint').select2({
    data:data,
    escapeMarkup: function (markup) {
       return markup;
    },
    minimumInputLength: 1,
    templateResult: formatRepo,
    templateSelection: formatRepoSelection
});
$.getJSON('/item/searchPaint',function(response){
    data=response;
    $('#search-paint').select2('refresh');
});

09-27 00:57