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的主要内容,如果未能解决你的问题,请参考以下文章