Select2 4 настраиваемый адаптер данных

Я пытаюсь создать собственный адаптер данных в соответствии с приведенным здесь примером: http://select2.github.io/announcements-4.0.html#query-to-data-adapter. Как я могу переместить строку, создающую элемент управления select2, за пределы функции с определением DataAdapter (см. код ниже)?

<!DOCTYPE html>
<head>
    <title></title>
    <link href="select2.css" rel="stylesheet" />
    <script type="text/javascript" src="http://code.jquery.com/jquery-2.1.4.js"></script>
    <script type="text/javascript" src="select2.full.js"></script>
    <script type="text/javascript">
        $.fn.select2.amd.require(
            ['select2/data/array', 'select2/utils'],
            function (ArrayData, Utils) {
                function CustomData ($element, options) {
                    CustomData.__super__.constructor.call(this, $element, options);
                }

                Utils.Extend(CustomData, ArrayData);

                CustomData.prototype.query = function (params, callback) {
                    var data = {results: []};
                    data.results.push({id: params.term, text: params.term});
                    data.results.push({id: 11, text: 'aa'});
                    data.results.push({id: 22, text: 'bb'});
                    callback(data);
                };

// Works if uncommented, but this line needs to be elsewhere (in $(document).ready()).
                //$("#my").select2({tags: true, dataAdapter: CustomData});
            });

        $(document).ready(function() {
// This line does not work here.            
            $("#my").select2({tags: true, dataAdapter: CustomData});
        });
    </script>
</head>
<body>
    <select id="my"></select>
</body>
</html>

person PowerGamer    schedule 04.08.2015    source источник


Ответы (2)


вы определяете его через AMD-Pattern:

$.fn.select2.amd.define('select2/data/customAdapter',[
        'select2/data/array',
        'select2/utils'
    ],
    function (ArrayAdapter, Utils) {

        function CustomDataAdapter ($element, options) {
            CustomDataAdapter.__super__.constructor.call(this, $element, options);
        }
        Utils.Extend(CustomDataAdapter, ArrayAdapter);

        CustomDataAdapter.prototype.current = function (callback) {

            callback(...);

        };

        return CustomDataAdapter;
    }
);

var customAdapter=$.fn.select2.amd.require('select2/data/customAdapter');

$("#my").select2({
    tags: true, 
    dataAdapter: customAdapter
});
person gunthor    schedule 20.08.2015
comment
У меня не работает, я получаю сообщение Невозможно получить свойство 'amd' неопределенной или нулевой ссылки: pastebin.com/yqarRJRu< /а> - person PowerGamer; 20.08.2015
comment
Я изменил все URL-адреса на онлайн-хосты (pastebin.com/0F053u3j), но все равно получаю ту же ошибку в IE11. - person PowerGamer; 21.08.2015
comment
ну, а если $.fn.select2 имеет значение null или undefined — вероятно, есть и другие проблемы, кроме amd (кеширование браузера?). - person gunthor; 21.08.2015
comment
также можно модифицировать AjaxAdapter, SelectAdapter и т.д. - person mmike; 12.01.2017
comment
Я совершенно не понимаю, как это работает. Вся эта сложная конструкция только для выполнения простых пользовательских функций... - person vladimir.gorea; 14.12.2017
comment
После реализации этого, как вы, например, устанавливаете выбранное значение select2 из базы данных? - person Gael Musi; 18.03.2020

Для тех, кто пытается расширить select2, вот пример:

// Require the adapter you want to override
$.fn.select2.amd.require(["select2/data/select"], function (Select) {
    let CustomDataAdapter = Select;

    // Simple example, just override the function
    CustomDataAdapter.prototype.current = function (callback) {
        // Your own code
    };

    // Example modifying data then calling the original function (which we need to keep)
    let originalSelect = CustomDataAdapter.prototype.select;
    CustomDataAdapter.prototype.select = function (data) {
        // Your own code
        // Call the original function while keeping 'this' context
        originalSelect.bind(this)(data);
    };

    // Finally, use the custom data adapter
    $('#my-select').select2({
        dataAdapter: CustomDataAdapter
    });

});
person ojathelonius    schedule 18.10.2019