我遇到了插入Select2()v4.0的问题。我想从boostrap中加载mi Modal中的远程数据并编辑这些值。我的代码是:
HTML
<select id="txtAsistentes" class="js-example-basic-multiple" multiple="multiple" style="width: 100%" />
JS
ControlToSelect2Format: function (controlId,ocultos) {
var control = "#" + controlId;
$(control).select2({
minimumInputLength: 2, // minimumInputLength for sending ajax request to server
width: 'resolve', // to adjust proper width of select2 wrapped elements
tags: false,
allowClear: false,
multiple: true,
ajax: {
url: "/Home/SearchUserAD/",
dataType: 'jsonp',
data: function (params) {
return {
term: params.term, // search term
page: params.page
};
},
processResults: function (data, page) {
return { results: data.Results };
}
},
initSelection: function (element, callback) {
var id = $("#hdReservaId").val();
if (id !== "") {
$.ajax({
url: "/Home/GetAsistentesReserva/",
dataType: "jsonp",
data: { idReserva: id }
}).done(function (data) {
callback(data.Results);
})
}
}
});
}
InitSelection确定,因为我使用“select2.full.min.js”,但问题是当我尝试编辑InitSelection预充值到我的select2控件的值时。我失去了价值并清除了控制。
如何在不删除值的情况下编辑初始值?
我的问题是我想要编辑之前创建和保存的数据。我不知道如何用select2()
进行编辑谢谢!
答案 0 :(得分:0)
最后我的解决方案是将此代码放在select()初始化之后,并删除代码initSelection:
var id = $("#hdReservaId").val();
if (id !== "") {
$.ajax({
url: "/Home/GetAsistentesReserva/",
dataType: "jsonp",
data: { idReserva: id }
}).then(function (data) {
data.Results.forEach(function (entry) {
//alert(entry);
var $option = $('<option selected>' + entry.text + '</option>').val(entry.id);
$(control).append($option).trigger('change');
});
$(control).trigger('change');
});
}
如果打开modal进行编辑,请调用ajax获取编辑数据。使用该方法,我可以毫无问题地编辑来自select2()multiselect的数据。
感谢您的支持!!