Example Disclosure for Navigation Menus
The following example demonstrates using the disclosure design pattern to show and hide dropdown lists of links in a navigation bar for a mythical university web site. Each disclosure button represents a section of the web site, and expanding it shows a list of links to pages within that section.
Note: Although this example uses the word menu
in the colloquial sense to refer to a set of navigation links, it does not use the WAI-ARIA menu
role.
Similar examples include:
- Example Disclosure (Show/Hide) for Answers to Frequently Asked Questions
- Example Disclosure (Show/Hide) for an Image Description
- Navigation Menubar Example
Example Usage Options
This example demonstrates two different ways of implementing keyboard support. Toggle between them with the following checkbox.
Example
Mythical University
Sample content section. Activating a link above will update and navigate to this region.
Accessibility Features
- Since this set of disclosure buttons controls visibility of navigation links for the mythical university web site, the list that contains them is wrapped in a navigation landmark named
Mythical University
. - The semantics of the list structure communicates the hierarchy of the navigation system to assistive technology users. The top-level set of three buttons is in a list of three items, and the set of links controlled by each button is contained within a list nested inside the item with the controlling button.
- If a dropdown is open and focus is inside the navigation region, pressing Esc will close the dropdown. Moving focus out of the navigation region also closes an open dropdown. Implementing this Esc behavior is necessary to meet the WCAG 2.1 1.4.13: Content on Hover or Focus criterion.
- The visual indicator of the show/hide state is created using CSS
::after
pseudo element border styles so the caret is reliably rendered in high contrast mode of operating systems and browsers. - Optional navigation keys (Arrow keys, Home, and End):
- Implementing the optional arrow key support prevents the default page scroll behavior when focus is contained within the navigation region.
- Optional navigation key support is primarily for the benefit of keyboard users who are not running a screen reader. Screen readers that have both reading and interaction modes intercept these navigation keys and do not pass them to the page when the screen reader is in reading mode. When interacting with this example, such screen readers are typically in reading mode because this example does not use a widget role that triggers screen reader interaction mode.
-
If implemented, the optional navigation keys supplement, but do not replace, tabbing among buttons and links.
This is because the buttons and links are not contained by an element with a widget role, such as
grid
, that is expected to occupy only one stop in the page Tab sequence and manage focus for all its descendants.
Keyboard Support
Key | Function |
---|---|
Tab Shift + Tab |
Move keyboard focus among top-level buttons, and if a dropdown is open, into and through links in the dropdown. |
Space or Enter |
|
Escape | If a dropdown is open, closes it and sets focus on the button that controls that dropdown. |
Down Arrow or Right Arrow (Optional) |
|
Up Arrow or Left Arrow (Optional) |
|
Home (Optional) |
|
End (Optional) |
|
Role, Property, State, and Tabindex Attributes
Role | Attribute | Element | Usage |
---|---|---|---|
aria-controls="IDREF"
|
button
|
The disclosure button controls visibility of the container identified by the IDREF value.
|
|
aria-expanded="false"
|
button
|
|
|
aria-expanded="true"
|
button
|
|
|
aria-current="page"
|
a
|
Indicates that the page referenced by the link is currently displayed. |
Javascript and CSS Source Code
- CSS: disclosure-navigation.css
- Javascript: disclosureMenu.js
HTML Source Code