gpt4 book ai didi

jquery - 动态设置选项时不启用 select2 allowedClear

转载 作者:行者123 更新时间:2023-12-03 21:30:38 25 4
gpt4 key购买 nike

当我创建由另一个 select2 下拉列表中的选择动态驱动的 select2 下拉列表时,更新后的下拉列表的 allowClear 按钮将被禁用。

如果我在 select 上构建 select2,销毁它,更新 html,然后重建它,这似乎并不重要:

var enableSelect2 = function () {
$(this).select2({
width: '200px',
allowClear: true,
minimumResultsForSearch: 7,
formatResult: function (result, container, query, escapeMarkup) {
var markup = [];
markMatchedSelect2Text(result.text, query.term, markup, escapeMarkup);
return markup.join('');
}
});
},
populateDropdown = function () {
var filterBy = this.id,
t = $(this);
$.ajax({
type: 'post',
url: '/search/get' + (filterBy === 'panel_id' ? 'Isps' : 'Packages') + '/' + t.val(),
success: function (data) {
var toRebuild,
target;
if (filterBy === 'panel_id') {
toRebuild = $('#isp_id, #package_id');
target = $('#isp_id');
} else {
toRebuild = $('#package_id');
target = $('#package_id');
}
toRebuild.each(function () {
$(this).select2('destroy');
});
target.html(data);
if (filterBy === 'panel_id') {
$('#package_id').html($(document.createElement('option')).attr('value', 0).text('Select ISP first\u2026'));
}
toRebuild.each(enableSelect2);
}
});
};

$('body').on('change', '#searchForm #isp_id, #searchForm #panel_id', populateDropdown);

或者如果我使用带有隐藏输入的 JSON:

$(function() {
var data = [
[{id:0,text:'black'},{id:1,text:'blue'}],
[{id:0,text:'9'},{id:1,text:'10'}]
];

$('#attribute').select2({allowClear: true}).on('change', function() {
$('#value').removeClass('select2-offscreen').select2({data:data[$(this).val()],allowClear: true});
}).trigger('change');
});

http://jsfiddle.net/eGXPe/116/

知道为什么清除按钮消失吗?

编辑:

抱歉,我没有澄清我的 html。在我的代码中,每个 select 都有一个 data-placeholder 属性。这不在我提供的 fiddle 中,因为它最初不是我的 fiddle ,而是从另一个 SO 问题借来的。我现在已经用数据占位符更新了那个 fiddle ,它可以工作: http://jsfiddle.net/eGXPe/119/ .

这是我之前未包含的 html 的 Twig 代码:

<li>
<label for="edit[panel_id]" class="hidden">Edit Panel ID?</label>
<input type="checkbox" id="edit[panel_id]" name="edit[panel_id]" />
<label for="panel_id">Panel:</label>
<select id="panel_id" name="panel_id" data-placeholder="Select a panel">
<option></option>
{% for panel in related.panel_id %}
<option value="{{ panel.value }}">{{ panel.name }}</option>
{% endfor %}
</select>
</li>
<li>
<label for="edit[isp_id]" class="hidden">Edit ISP ID?</label>
<input type="checkbox" id="edit[isp_id]" name="edit[isp_id]" />
<label for="isp_id">ISP:</label>
<select id="isp_id" name="isp_id" data-placeholder="Select an ISP">
<option></option>
{% for isp in related.isp_id %}
<option value="{{ isp.value }}">{{ isp.name }}</option>
{% endfor %}
</select>
</li>
<li>
<label for="edit[package_id]" class="hidden">Edit Package ID?</label>
<input type="checkbox" id="edit[package_id]" name="edit[package_id]" />
<label for="package_id">Package:</label>
<select id="package_id" name="package_id" data-placeholder="Select a package">
<option></option>
<option value="0">Select ISP first&hellip;</option>
</select>
</li>

最佳答案

stated in the docallowClear需要一个placeholderplaceholder需要一个对应的option值(不能是空字符串,但可以是一个空格)。

allowClear

This option only works when the placeholder is specified.

--

placeholder

Note that because browsers assume the first option element is selected in non-multi-value select boxes an empty first option element must be provided () for the placeholder to work.

所以你的代码应该是这样的:

$('#attribute').select2({
allowClear: true,
placeholder: "Select an attribute"
}).on('change', function() {
$('#value')
.removeClass('select2-offscreen')
.select2({
data:data[$(this).val()],
allowClear: true,
placeholder: "Select a value"
});
}).trigger('change');

http://jsfiddle.net/eGXPe/118/

关于jquery - 动态设置选项时不启用 select2 allowedClear,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19766025/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com