Select2 Event for creating a new tag

前端 未结 3 1191
闹比i
闹比i 2021-01-01 15:58

I\'m using the jQuery Select2 (v4) plugin for a tag selector.

I want to listen for when a new tag is created in the select element and fire an ajax request to store

3条回答
  •  感情败类
    2021-01-01 16:19

    I can't find any native method unfortunately. But if you're interested in simple "workarounds", maybe this get you closer:

    $('.select2').select2({
        tags: true,
        tokenSeparators: [",", " "],
        createTag: function (tag) {
            return {
                id: tag.term,
                text: tag.term,
                // add indicator:
                isNew : true
            };
        }
    }).on("select2:select", function(e) {
        if(e.params.data.isNew){
            // append the new option element prenamently:
            $(this).find('[value="'+e.params.data.id+'"]').replaceWith('');
            // store the new tag:
            $.ajax({
                // ... 
            });
        }
    });
    

    DEMO


    [EDIT]
    (Small update: see @Alex comment below)

    The above will work only if the tag is added with mouse. For tags added by hitting space or comma, use change event.

    Then you can filter option with data-select2-tag="true" attribute (new added tag):

    $('.select2').select2({
        tags: true,
        tokenSeparators: [",", " "]
    }).on("change", function(e) {
        var isNew = $(this).find('[data-select2-tag="true"]');
        if(isNew.length && $.inArray(isNew.val(), $(this).val()) !== -1){
            isNew.replaceWith('');
            $.ajax({
                // ... store tag ...
            });
        }
    });
    

    DEMO 2

提交回复
热议问题