Editable Combobox With List Autocomplete Example
Read This First
The code in this example is not intended for production environments.
Before using it for any purpose, read this to understand why.
This is an illustrative example of one way of using ARIA that conforms with the ARIA specification.
- There may be support gaps in some browser and assistive technology combinations, especially for mobile/touch devices. Testing code based on this example with assistive technologies is essential before considering use in production systems.
- The ARIA and Assistive Technologies Project is developing measurements of assistive technology support for APG examples.
- Robust accessibility can be further optimized by choosing implementation patterns that maximize use of semantic HTML and heeding the warning that No ARIA is better than Bad ARIA.
About This Example
The below combobox for choosing the name of a US state or territory demonstrates the Combobox Pattern. The design pattern describes four types of autocomplete behavior. This example illustrates the autocomplete behavior known as list autocomplete with manual selection. If the user types one or more characters in the edit box and the typed characters match the beginning of the name of one or more states or territories, a listbox popup appears containing the matching names. When the listbox appears, a suggested name is not automatically selected. Thus, after typing, if the user tabs or clicks out of the combobox without choosing a value from the listbox, the typed string becomes the value of the combobox. Note that this implementation enables users to input the name of a state or territory, but it does not prevent input of any other arbitrary value.
Similar examples include:
- Select-Only Combobox: A single-select combobox with no text input that is functionally similar to an HTML
select
element. - Editable Combobox with Both List and Inline Autocomplete: An editable combobox that demonstrates the autocomplete behavior known as
list with inline autocomplete
. - Editable Combobox Without Autocomplete: An editable combobox that demonstrates the behavior associated with
aria-autocomplete=none
. - Editable Combobox with Grid Popup: An editable combobox that presents suggestions in a grid, enabling users to navigate descriptive information about each suggestion.
- Date Picker Combobox: An editable date input combobox that opens a dialog containing a calendar grid and buttons for navigating by month and year.
Example
- Alabama
- Alaska
- American Samoa
- Arizona
- Arkansas
- California
- Colorado
- Connecticut
- Delaware
- District of Columbia
- Florida
- Georgia
- Guam
- Hawaii
- Idaho
- Illinois
- Indiana
- Iowa
- Kansas
- Kentucky
- Louisiana
- Maine
- Maryland
- Massachusetts
- Michigan
- Minnesota
- Mississippi
- Missouri
- Montana
- Nebraska
- Nevada
- New Hampshire
- New Jersey
- New Mexico
- New York
- North Carolina
- North Dakota
- Northern Marianas Islands
- Ohio
- Oklahoma
- Oregon
- Pennsylvania
- Puerto Rico
- Rhode Island
- South Carolina
- South Dakota
- Tennessee
- Texas
- Utah
- Vermont
- Virginia
- Virgin Islands
- Washington
- West Virginia
- Wisconsin
- Wyoming
Accessibility Features
- Browsers do not manage visibility of elements referenced by aria-activedescendant like they do for elements with focus. When a keyboard event changes the active option in the listbox, the JavaScript scrolls the option referenced by aria-activedescendant into view. Managing aria-activedescendant visibility is essential to accessibility for people who use a browser's zoom feature to increase the size of content.
-
To enhance perceivability when operating the combobox, visual keyboard focus and hover are styled using the CSS
:hover
pseudo-class, andfocus
andblur
event handlers:- To make it easier to perceive when the combobox receives focus, focus creates a 2 pixel focus ring around both the
input
andbutton
elements with 2 pixels of space between the focus ring and the combobox. - To make it easier to perceive that either the input or button can be clicked to open the listbox, hover causes the same styling as focus.
- To help people with visual impairments identify the combobox as an interactive element, the cursor is changed to a pointer when hovering over the combobox or list.
- To make it easier to distinguish the selected listbox option from other options, selection creates a 2 pixel border above and below the option.
- Note: Because transparent borders are visible on some systems with operating system high contrast settings enabled, transparency cannot be used to create a visual difference between the element that is focused an other elements. Instead of using transparency, the focused element has a thicker border and less padding. When an element receives focus, its border changes from zero to two pixels and padding is reduced by two pixels. When an element loses focus, its border changes from two pixels to two and padding is increased by two pixels.
- To make it easier to perceive when the combobox receives focus, focus creates a 2 pixel focus ring around both the
-
To ensure the inline SVG graphic used for the arrow in the open button has sufficient contrast with the background when high contrast settings change the color of text content, CSS
forced-color-adjust
is set toauto
on thesvg
element and and thefill
attribute of thepolygon
element is set tocurrentcolor
. This causes the colors of thefill
of the polygon elements to be overridden by the high contrast color setting. Ifforced-color-adjust
were not used to override the colors specified for thefill
property, the color would remain the same in high contrast mode, which could lead to insufficient contrast between the arrow and the background or even make it invisible if the color matched the high contrast mode background.
Note: The explicit setting offorced-color-adjust
is necessary because some browsers do not useauto
as the default value for SVG graphics.
Keyboard Support
The example combobox on this page implements the following keyboard interface. Other variations and options for the keyboard interface are described in the Keyboard Interaction section of the Combobox Pattern.
Textbox
Key | Function |
---|---|
Down Arrow |
|
Alt + Down Arrow | Opens the listbox without moving focus or changing selection. |
Up Arrow |
|
Enter | Closes the listbox if it is displayed. |
Escape |
|
Standard single line text editing keys |
|
Listbox Popup
NOTE: When visual focus is in the listbox, DOM focus remains on the textbox and the value of aria-activedescendant
on the textbox is set to a value that refers to the listbox option that is visually indicated as focused.
Where the following descriptions of keyboard commands mention focus, they are referring to the visual focus indicator.
For more information about this focus management technique, see
Managing Focus in Composites Using aria-activedescendant.
Key | Function |
---|---|
Enter |
|
Escape |
|
Down Arrow |
|
Up Arrow |
|
Right Arrow | Moves visual focus to the textbox and moves the editing cursor one character to the right. |
Left Arrow | Moves visual focus to the textbox and moves the editing cursor one character to the left. |
Home | Moves visual focus to the textbox and places the editing cursor at the beginning of the field. |
End | Moves visual focus to the textbox and places the editing cursor at the end of the field. |
Printable Characters |
|
Button
The button has been removed from the tab sequence of the page, but is still important to assistive technologies for mobile devices that use touch events to open the list of options.
Role, Property, State, and Tabindex Attributes
The example combobox on this page implements the following ARIA roles, states, and properties. Information about other ways of applying ARIA roles, states, and properties is available in the Roles, States, and Properties section of the Combobox Pattern.
Textbox
Role | Attribute | Element | Usage |
---|---|---|---|
combobox
|
input[type="text"] |
Identifies the input as a combobox. | |
aria-autocomplete="list"
|
input[type="text"] |
Indicates that the autocomplete behavior of the text input is to suggest a list of possible values in a popup and that the suggestions are related to the string that is present in the textbox. | |
aria-controls="ID_REF"
|
input[type="text"] |
Identifies the element that serves as the popup. | |
aria-expanded="false"
|
input[type="text"] |
Indicates that the popup element is not displayed. | |
aria-expanded="true"
|
input[type="text"] |
Indicates that the popup element is displayed. | |
id="string"
|
input[type="text"] |
|
|
aria-activedescendant="ID_REF"
|
input[type="text"] |
|
Listbox Popup
Role | Attribute | Element | Usage |
---|---|---|---|
listbox
|
ul
|
Identifies the ul element as a listbox . |
|
aria-label="States"
|
ul |
Provides a label for the listbox . |
|
option
|
li |
|
|
aria-selected="true"
|
li |
|
Button
Role | Attribute | Element | Usage |
---|---|---|---|
tabindex="-1"
|
button |
Removes the button from the tab sequence of the page because its function is redundant with the keyboard operation of the combobox. | |
aria-label="States"
|
button |
Provides a label for the button . |
|
aria-controls="ID_REF"
|
button |
Identifies the element that serves as the popup. | |
aria-expanded="false"
|
button |
Indicates that the popup element is not displayed. | |
aria-expanded="true"
|
button |
Indicates that the popup element is displayed. |
Javascript and CSS Source Code
- CSS: combobox-autocomplete.css
- Javascript: combobox-autocomplete.js
HTML Source Code
<label for="cb1-input">
State
</label>
<div class="combobox combobox-list">
<div class="group">
<input id="cb1-input"
class="cb_edit"
type="text"
role="combobox"
aria-autocomplete="list"
aria-expanded="false"
aria-controls="cb1-listbox">
<button id="cb1-button"
tabindex="-1"
aria-label="States"
aria-expanded="false"
aria-controls="cb1-listbox">
<svg width="18"
height="16"
aria-hidden="true"
focusable="false"
style="forced-color-adjust: auto">
<polygon class="arrow"
stroke-width="0"
fill-opacity="0.75"
fill="currentcolor"
points="3,6 15,6 9,14"></polygon>
</svg>
</button>
</div>
<ul id="cb1-listbox"
role="listbox"
aria-label="States">
<li id="lb1-al" role="option">
Alabama
</li>
<li id="lb1-ak" role="option">
Alaska
</li>
<li id="lb1-as" role="option">
American Samoa
</li>
<li id="lb1-az" role="option">
Arizona
</li>
<li id="lb1-ar" role="option">
Arkansas
</li>
<li id="lb1-ca" role="option">
California
</li>
<li id="lb1-co" role="option">
Colorado
</li>
<li id="lb1-ct" role="option">
Connecticut
</li>
<li id="lb1-de" role="option">
Delaware
</li>
<li id="lb1-dc" role="option">
District of Columbia
</li>
<li id="lb1-fl" role="option">
Florida
</li>
<li id="lb1-ga" role="option">
Georgia
</li>
<li id="lb1-gm" role="option">
Guam
</li>
<li id="lb1-hi" role="option">
Hawaii
</li>
<li id="lb1-id" role="option">
Idaho
</li>
<li id="lb1-il" role="option">
Illinois
</li>
<li id="lb1-in" role="option">
Indiana
</li>
<li id="lb1-ia" role="option">
Iowa
</li>
<li id="lb1-ks" role="option">
Kansas
</li>
<li id="lb1-ky" role="option">
Kentucky
</li>
<li id="lb1-la" role="option">
Louisiana
</li>
<li id="lb1-me" role="option">
Maine
</li>
<li id="lb1-md" role="option">
Maryland
</li>
<li id="lb1-ma" role="option">
Massachusetts
</li>
<li id="lb1-mi" role="option">
Michigan
</li>
<li id="lb1-mn" role="option">
Minnesota
</li>
<li id="lb1-ms" role="option">
Mississippi
</li>
<li id="lb1-mo" role="option">
Missouri
</li>
<li id="lb1-mt" role="option">
Montana
</li>
<li id="lb1-ne" role="option">
Nebraska
</li>
<li id="lb1-nv" role="option">
Nevada
</li>
<li id="lb1-nh" role="option">
New Hampshire
</li>
<li id="lb1-nj" role="option">
New Jersey
</li>
<li id="lb1-nm" role="option">
New Mexico
</li>
<li id="lb1-ny" role="option">
New York
</li>
<li id="lb1-nc" role="option">
North Carolina
</li>
<li id="lb1-nd" role="option">
North Dakota
</li>
<li id="lb1-mp" role="option">
Northern Marianas Islands
</li>
<li id="lb1-oh" role="option">
Ohio
</li>
<li id="lb1-ok" role="option">
Oklahoma
</li>
<li id="lb1-or" role="option">
Oregon
</li>
<li id="lb1-pa" role="option">
Pennsylvania
</li>
<li id="lb1-pr" role="option">
Puerto Rico
</li>
<li id="lb1-ri" role="option">
Rhode Island
</li>
<li id="lb1-sc" role="option">
South Carolina
</li>
<li id="lb1-sd" role="option">
South Dakota
</li>
<li id="lb1-tn" role="option">
Tennessee
</li>
<li id="lb1-tx" role="option">
Texas
</li>
<li id="lb1-ut" role="option">
Utah
</li>
<li id="lb1-ve" role="option">
Vermont
</li>
<li id="lb1-va" role="option">
Virginia
</li>
<li id="lb1-vi" role="option">
Virgin Islands
</li>
<li id="lb1-wa" role="option">
Washington
</li>
<li id="lb1-wv" role="option">
West Virginia
</li>
<li id="lb1-wi" role="option">
Wisconsin
</li>
<li id="lb1-wy" role="option">
Wyoming
</li>
</ul>
</div>