使用Select2()4.0

时间:2015-07-13 14:20:09

标签: twitter-bootstrap asp.net-mvc-4 jquery-select2 jquery-select2-4

我遇到了插入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()

进行编辑

谢谢!

1 个答案:

答案 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的数据。

感谢您的支持!!