невозможно вызвать val(), если initSelection() не определена ошибка в плагине select2

Я использую плагин select2 для загрузки удаленных данных. Я использую страницу aspx, которая возвращает данные JSON, и то же самое назначается плагину select2. После того, как пользователь выбирает какое-либо значение из текстового поля select2, я заставляю страницу выполнять обратную передачу. После обратной передачи я использую следующий код для перезагрузки, чтобы установить текст в текстовом поле select2.

var data = { "PatientID": "XYX", "Email": "[email protected]" };

            $('#e6').select2('val', '123');

Но система выдает следующую ошибку: cannot call val() if initSelection() is not defined

Даже если я определяю init, я не могу установить значение. Я использую следующий код. Пожалуйста, помогите мне установить значение в текстовом поле select2 после обратной передачи.

$(document).ready(function () {
        $("#e6").select2({
            placeholder: "Search for a movie",
            minimumInputLength: 1,
            ajax: { // instead of writing the function to execute the request we use Select2's convenient helper
                url: "data.aspx", 
                dataType: 'json',
                quietMillis: 1000,
                data: function (term, page) {
                    return {
                        name: term
                    };
                },
                initSelection: function (element, callback) {
                    var data = { "PatientID": "XYX", "Email": "[email protected]" };
                    callback(data);
                },

                results: function (data) {
                    var results = [];
                    $.each(data, function (index, item) {
                        results.push({
                            id: item['Email'],
                            text: item['PatientID']
                        });
                    });
                    return {
                        results: results
                    };
                },
            },
        });

    });

    window.onload = function () {
        var data = { "PatientID": "XYX", "Email": "[email protected]" };
        //When this is called system is throwing error
        //This code is required to show the value in select2 textbox after the post back
        $('#e6').select2('val', data);
    }

    $(document).ready(function () {
        $("#e6").on("select2-selecting", function (e) {
            //alert("selecting val=" + e.val + " choice=" + JSON.stringify(e.choice));
            var id = document.getElementById('<%= savebtn.ClientID %>');
            document.getElementById('<%= hdnFld.ClientID %>').value = e.val;
            id.value = e.val;
            //causes post back
            id.click();

        });
    });

person SharpCoder    schedule 20.08.2013    source источник
comment
initSelection не должно находиться внутри свойства ajax.   -  person user1983983    schedule 22.08.2013


Ответы (1)


В вашем скрипте ошибка. У меня была такая же проблема, и я увидел ваш вопрос. После того, как я прочитал документы API Select2, я понял свою ошибку.

Вы должны разместить initSelection на том же уровне, что и ajax. например

$("#e6").select2({
        placeholder: "Search for a movie",
        minimumInputLength: 1,
        initSelection: function (element, callback) {
                var data = { "PatientID": "XYX", "Email": "[email protected]" };
                callback(data);
            },
        ajax: { // instead of writing the function to execute the request we use Select2's convenient helper
            url: "data.aspx", 
            dataType: 'json',
            quietMillis: 1000,
            data: function (term, page) {
                return {
                    name: term
                };
            },


            results: function (data) {
                var results = [];
                $.each(data, function (index, item) {
                    results.push({
                        id: item['Email'],
                        text: item['PatientID']
                    });
                });
                return {
                    results: results
                };
            },
        },
    });
person Arthur Wang    schedule 15.08.2014