I have a select box in which i can select multiple options. In the select box are multiple optgroups. Is there an easy way to select a whole optgroup at once in javascript?
相关问题
- Views base64 encoded blob in HTML with PHP
- Is there a limit to how many levels you can nest i
- How to toggle on Order in ReactJS
- void before promise syntax
- Keeping track of variable instances
I suggest using jQuery (or another framework) to quickly handle DOM selections. Give each optgroup a class to make it easier to grab it.
If you want to select the entire group based on the user selecting the group, do the following:
**Both examples are untested pseudo-code, but they should work with minimal changes, if necessary.
If you cannot use a framework, you'll have to traverse the DOM yourself to find the optgroup and children. You could attach a listener to the
select
element to grab the element being selected then traverse to the children that way, too.I was trying to do something similar just now.
I wanted to select an
<optgroup>
's<option>
s upon clicking the group's label. The first attempt went like this:This solution half worked...
Upon clicking the
<optgroup>
's label all of its children became selected.BUT when simply clicking an
<option>
it was still selecting all the other<option>
s in the group! The problem was event bubbling, because the<option>
is inside the<optgroup>
technically you're clicking it too.Therefore the final piece of the puzzle was to suppress the event bubbling upwards in the event that an
<option>
was actually clicked instead. The final solution then became:Job done!
EDIT
Infuriatingly this doesn't work work in IE8 (and doubtful < IE8 - maybe IE9?)...
It decides to totally ignore click events on both and elements. The only alternative that I can think of is to position elements above the optgroup labels to capture the click, but its probably not worth the effort...
I'm normally against using jQuery for simple jobs like this but I can see its value here. Still, if you prefer a non-jQuery solution that will have the benefits of using no library, introducing no spurious ids or classes and running faster, here is one:
If your
<optgroup>
has an id you could do away with theselectOptGroup
function and just pass the optgroup straight intoselectOptGroupOptions
.jquery: