admin管理员组文章数量:1345316
I am using the jQuery plugin Select2
If I have a multiselect with the following structure:
<select name="search-term[]" multiple="multiple">
<optgroup label="Categories">
<option value="category_4">Internal</option>
<option value="category_2">Business</option>
<option value="category_5">External</option>
<option value="category_1">Science</option>
<option value="category_6">Sports and Social</option>
</optgroup>
<optgroup label="Event Types">
<option value="eventtype_2">Meeting</option>
<option value="eventtype_3">Social Activity</option>
<option value="eventtype_4">Sporting Activity</option>
<option value="eventtype_1">Symposium</option>
</optgroup>
<optgroup label="Locations">
<option value="location_2">Office 1</option>
<option value="location_3">Office 2</option>
<option value="location_1">Office 3</option>
</optgroup>
</select>
If I select "Office 1" under the optgroup labelled Locations then the label on the selected option says "Office 1"
Is there a way to change this so that it shows the optgroup label as well so the label on the selection option would say "Location: Office 1".
See the following image for the label I am referring to:
I am using the jQuery plugin Select2
If I have a multiselect with the following structure:
<select name="search-term[]" multiple="multiple">
<optgroup label="Categories">
<option value="category_4">Internal</option>
<option value="category_2">Business</option>
<option value="category_5">External</option>
<option value="category_1">Science</option>
<option value="category_6">Sports and Social</option>
</optgroup>
<optgroup label="Event Types">
<option value="eventtype_2">Meeting</option>
<option value="eventtype_3">Social Activity</option>
<option value="eventtype_4">Sporting Activity</option>
<option value="eventtype_1">Symposium</option>
</optgroup>
<optgroup label="Locations">
<option value="location_2">Office 1</option>
<option value="location_3">Office 2</option>
<option value="location_1">Office 3</option>
</optgroup>
</select>
If I select "Office 1" under the optgroup labelled Locations then the label on the selected option says "Office 1"
Is there a way to change this so that it shows the optgroup label as well so the label on the selection option would say "Location: Office 1".
See the following image for the label I am referring to:
Share Improve this question asked Mar 15, 2016 at 17:08 tuscan88tuscan88 5,83912 gold badges56 silver badges111 bronze badges 1- I think this is what you are looking for: stackoverflow./questions/19037232/… – cralfaro Commented Mar 15, 2016 at 17:40
3 Answers
Reset to default 6I sorted it in the end using the templateSelection option like so:
$('select').select2({
templateSelection: function(item)
{
value = item.id;
select_name = item.element.offsetParent.name;
optgroup_label = $('select[name="'+ select_name +'"] option[value="'+ value +'"]').parent('optgroup').prop('label');
if(typeof optgroup_label != 'undefined') {
return optgroup_label+': ' + item.text;
} else {
return item.text;
}
}
});
I do a jsFiddle for you, see https://jsfiddle/vcwrjpny/
$('option').click(function() {
alert($(this).parent('optgroup').attr('label'));
})
EDIT :
with plugin select2 :
Do like that : see here http://jsfiddle/bJxFR/68/
function format(item) {
opt = $('select').find(':selected');
sel = opt.text();
og = opt.closest('optgroup').attr('label');
alert('your optgroup is : ' + og);
return item.text;
}
$("select").select2({
formatSelection: format,
escapeMarkup: function(m) { return m; }
});
When I attempted to use geoffs3310's solution I found that it was generating an error in IE11 about item.element.offsetParent being undefined. I ended up ing up with an alternative solution which seems a bit less plicated. I used this function for my templateSelection:
function select2IncludeOptgroupSelection(item) {
// If the element does not belong to an optgroup, just return the text
if ((item.element.parentElement.tagName != 'OPTGROUP') || !item.element.parentElement.label) {
return item.text;
}
else {
return item.element.parentElement.label + ': ' + item.text;
}
}
In my case we use script to load all our standard select2 settings for all multi-selects, so I wanted to make the function only apply if a specific class was on the select field. So this is the version I ended up using:
function select2IncludeOptgroupSelection(item) {
// If the element does not belong to an optgroup, just return the text
if (item.element.parentElement.tagName != 'OPTGROUP') {
return item.text;
}
// If we are still here, determine whether we want to add the label
var select_name = item.element.parentElement.parentElement.name;
var addOptgroup = $('select[name="'+ select_name +'"]').hasClass('selection-add-optgroup');
if (addOptgroup && item.element.parentElement.label) {
return item.element.parentElement.label + ': ' + item.text;
}
else {
return item.text;
}
}
本文标签: javascriptjQuery select2 show optgroup label when selectedStack Overflow
版权声明:本文标题:javascript - jQuery select2 show optgroup label when selected - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743811814a2543209.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论