HTML

Chapter 27: Selection Menu Controls

Select Menu

The <select> element generates a drop-down menu from which the user can choose an option.

<select name="">
 <option value="1">One</option>
 <option value="2">Two</option>
 <option value="3">Three</option>
 <option value="4">Four</option>
</select>

Changing the Size

You can change the size of the selection menu with the size attribute. A size of 0 or 1 displays the standard dropdown style menu. A size greater than 1 will convert the drop-down into a box displaying that many lines, with one
option per line and a scrollbar in order to scroll through the available options.

<select name="" size="4"></select>

Multi-option Selection Menus

By default, users can only select a single option. Adding the multiple attribute allows users to select multiple
options at once and submit all selected options with the form. Using the multiple attribute automatically converts
the drop-down menu into a box as if it had a size defined. The default size when this occurs is determined by the
specific browser you are using, and it is not possible to change it back to a drop-down style menu while allowing
multiple selections.

<select name="" multiple></select>

When using the multiple attribute, there is a difference between using 0 and 1 for the size, whereas no difference
exists when not using the attribute. Using 0 will cause the browser to behave in whatever default manner it is
programmed to do. Using 1 will explicitly set the size of the resulting box to only one row high.

Options

The options inside a selection menu are what the user will be selection. The normal syntax for an option is as
follows:

<option>Some Option</option>

However, it’s important to note that the text inside the <option> element itself is not always used, and essentially becomes the default value for attributes which are not specified.

The attributes which control the actual appearance and function of the option are value and label. The label
represents the text which will be displayed in the drop-down menu (what you’re looking at and will click on to select
it). The value represents the text which will be sent along with form submission. If either of these values is omitted,
it uses the text inside the element as the value instead. So the example we gave above could be “expanded” to this:

<option label="Some Option" value="Some Option">

Note the omission of the inside text and end tag, which are not required to actually construct an option inside
menu. If they were included, the inside text would be ignored because both attributes are already specified and the
text is not needed. However, you probably won’t see a lot of people writing them this way. The most common way
it’s written is with a value that will be sent to the server, along with the inside text which eventually becomes the
label attribute, like so:

<option value="option1">Some Option</option>

Selecting an option by default

You can also specify a certain option to be selected in the menu by default by attaching the selected attribute to it.
By default, if no option is specified as selected in the menu, the first option in the menu will be selected when
rendered. If more than one option has the selected attribute attached, then the last option present in the menu
with the attribute will be the one selected by default.

<option value="option1" selected>Some option</option>

If you’re using the attribute in a multi-option selection menu, then all the options with the attribute will be selected
by default, and none will be selected if no options have the attribute.

<select multiple>
 <option value="option1" selected>Some option</option>
 <option value="option2" selected>Some option</option> 
</select>

Option Groups

You can neatly group your options within a selection menu in order to provide a more structured layout in a long list of options by using the <optgroup> element.

The syntax is very basic, by simply using the element with a label attribute to identify the title for the group, and
containing zero or more options that should be within that group.

<select name="">
 <option value="milk">Milk</option>
 <optgroup label="Fruits">
 <option value="banana">Bananas</option>
 <option value="strawberry">Strawberries</option>
 </optgroup>
 <optgroup label="Vegetables" disabled>
 <option value="carrot">Carrots</option>
 <option value="zucchini">Zucchini</option>
 </optgroup>
</select>

When using option groups, not all options need to be contained within a group. As well, disabling an option group
will disable all options within the group, and it is not possible to manually re-enable a single option within a
disabled group.

Datalist

The <datalist> tag specifies a list of pre-defined options for an <input> element. It provide an “autocomplete” feature on <input> elements. Users will see a drop-down list of options as they write.

<input list="Languages">
<datalist id="Languages">
 <option value="PHP">
 <option value="Perl">
 <option value="Python">
 <option value="Ruby">
 <option value="C+">
</datalist>

Browser Support

ChromeEdgeMozillaSafariOpera
20.010.04.0Not Supported9.0

Recent Posts

Unlocking the Secrets of JSON.stringify(): More Than Meets the Eye

JSON (JavaScript Object Notation) is a lightweight data-interchange format widely used in web development. At…

3 months ago

How to Handle AJAX GET/POST Requests in WordPress

AJAX (Asynchronous JavaScript and XML) is a powerful technique used in modern web development that…

4 months ago

Page Speed Optimization: Post-Optimization Dos and Don’ts

Introduction After successfully optimizing your website for speed, it's essential to maintain and build upon…

4 months ago

Ultimate Guide to Securing WordPress Folders: Protect Your Site from Unauthorized Access

Securing your WordPress folders is crucial to safeguarding your website from unauthorized access and potential…

5 months ago

HTML CSS PHP File Upload With Circle Progress Bar

Creating a file upload feature with a circular progress bar involves multiple steps. You'll need…

5 months ago

Using WP Rocket with AWS CloudFront CDN

Integrating WP Rocket with AWS CloudFront CDN helps to optimize and deliver your website content…

5 months ago