Select2 JQuery不会通过按钮添加新选择器来更新Dom

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Select2 JQuery不会通过按钮添加新选择器来更新Dom相关的知识,希望对你有一定的参考价值。

我正在使用选择器2(https://select2.org),我有一个选择器,以便选择食物。我希望添加一个带底部的新选择器。我已经做到了但是当Dom刷新时,它向我展示了一个糟糕的选择器:up good selector and in down the new selector (the bad selector)

<div class="container">
    <div class="row">
        <!-- style="padding-top: 1rem; padding-left: 2rem" -->
        <div class="col-sm-12">
            <b>Food:</b>
            <select id="selectpicker1" data-live-search="true" data-width="70%">
                <option data-tokens="Hotdog" value="Hotdog">Hot Dog</option>
                <option data-tokens="Burger" value="Burger">Burger</option>
                <option data-tokens="Sugar" value="Sugar">Sugar</option>
                <option data-tokens="Donut" value="Sugar">Donut</option>
            </select>
            <button id="b1" class="add-more btn-success" type="button" onclick="doFunction()" ;>+</button>
        </div>
    </div>
    <div id="ss"></div>
    <script>
        function doFunction() {
            $(ss).append
            (
                '<div class="row">' +
                '<div class="col-sm-12">' +
                '<b>Food:</b>' +
                '<select  id="selectpicker1" data-live-search="true" data-width="70%">' +
                '<option data-tokens="Hotdog" value="Hotdog">Hot Dog<option>' +
                '<option data-tokens="Burger" value="Burger">Burger</option>' +
                '<option data-tokens="Sugar" value="Sugar">Sugar</option>' +
                '<option data-tokens="Donut" value="Sugar">Donut</option>' +
                '</select>' +
                '<button id="b1" class="add-more btn-success" type="button" onclick="doFunction()";>+</button>' +
                '</div>' +
                '</div>'
            );
        }
    </script>
</div>

你有什么想法来解决它吗?

答案

您只需要在逻辑后调用select2函数:

   <script>
    function doFunction() {
        $(ss).append
        (
            '<div class="row">' +
            '<div class="col-sm-12">' +
            '<b>Food:</b>' +
            '<select  id="selectpicker1" data-live-search="true" data-width="70%">' +
            '<option data-tokens="Hotdog" value="Hotdog">Hot Dog<option>' +
            '<option data-tokens="Burger" value="Burger">Burger</option>' +
            '<option data-tokens="Sugar" value="Sugar">Sugar</option>' +
            '<option data-tokens="Donut" value="Sugar">Donut</option>' +
            '</select>' +
            '<button id="b1" class="add-more btn-success" type="button" onclick="doFunction()";>+</button>' +
            '</div>' +
            '</div>'
        );
      // Here you can add the initialize
      // Important be sure you insert the library select 2 
      // If is not the case you will get an error undefined select2() 
      $('select').select2();

    }
</script>

请注意,如果您不将select2应用于所有选择,则可以将select更改为任何其他选择器。

以上是关于Select2 JQuery不会通过按钮添加新选择器来更新Dom的主要内容,如果未能解决你的问题,请参考以下文章

jquery Select2 防止在 ajax 响应中选择

让 Select2 Gem 与 A​​ctiveAdmin“添加新”按钮一起使用

使用jquery动态添加时select2不起作用

动态添加部分视图后如何重新初始化JQuery

使用 jQuery 的 select2 向多选添加值

如何使用配置了ajax搜索的select2 jquery插件实现选择所有功能。?