当前,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');
});