【发布时间】:2020-03-04 22:45:06
【问题描述】:
我使用select2 bootstrap theme 将Bootstrap 4 主题添加到select2,并且需要使用formatState 方法将<span></span> 添加到文本中。
我的 HTML 代码是:
<div class="fieldset fieldset-1">
<label for="color">Choose color</label>
<select name="color" class="select2">
<option value="grn">Green</option>
<option value="blu">Blue</option>
<option value="brn">Brown</option>
<option value="blk">Black</option>
<option value="red">Red</option>
<option value="yel">Yellow</option>
<option value="wht">White</option>
</select>
</div>
还有Js:
function formatState (state) {
if (!state.id) {
return state.text;
}
var baseUrl = "/user/pages/images/flags";
var $state = $(
'<span><img src="' + baseUrl + '/' + state.element.value.toLowerCase() + '.png" class="img-flag" /> ' + state.text + '</span>'
);
return $state;
};
$(".select2").select2({
templateResult: formatState
});
$('select').select2({
theme: 'bootstrap4',
});
在行动 select2 不显示<span></span>。我检查了我的 Js 代码并删除了这一行(bootstrap 4 主题):
$('select').select2({
theme: 'bootstrap4',
});
现在 select2 工作,我看到 <span></span>。我该如何解决这个问题?!
【问题讨论】:
标签: javascript jquery jquery-select2