Home
Sample content section. Activating a link above will update and navigate to this region.
Note: This is an illustrative example of one way of using ARIA that conforms with the ARIA specification.
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. That is because the menu and menubar roles require complex functionality, such as composite widget focus management and first-character navigation, that is unnecessary for typical site navigation.
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. Unlike the other disclosure navigation menu example, this example includes top-level links alongside the disclosure buttons.
Similar examples include:
This example demonstrates two different ways of implementing keyboard support. Toggle between them with the following checkbox.
Sample content section. Activating a link above will update and navigate to this region.
Mythical University.
grid
, that is expected to occupy only one stop in the page Tab sequence and manage focus for all its descendants.
Key | Function |
---|---|
Tab Shift + Tab |
Move keyboard focus among top-level links and buttons, and if a dropdown is open, 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 | Attribute | Element | Usage |
---|---|---|---|
aria-controls="IDREF"
|
button
|
Indicates that 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. |
<header class="sample-header">
<div class="title" id="id_website_title">
Mythical University
</div>
<div class="tagline">
Using a disclosure + link pattern for navigation
</div>
</header>
<nav aria-label="Mythical University">
<ul id="exTest" class="disclosure-nav">
<li>
<a href="#mythical-page-content" class="main-link">
About
</a>
<button type="button"
aria-expanded="false"
aria-controls="id_about_menu"
aria-label="More About pages">
</button>
<ul id="id_about_menu" style="display:none">
<li>
<a href="#mythical-page-content">
Overview
</a>
</li>
<li>
<a href="#mythical-page-content">
Administration
</a>
</li>
<li>
<a href="#mythical-page-content">
Facts
</a>
</li>
<li>
<a href="#mythical-page-content">
Campus Tours
</a>
</li>
</ul>
</li>
<li>
<a href="#mythical-page-content" class="main-link">
Admissions
</a>
<button type="button"
aria-expanded="false"
aria-controls="id_admissions_menu"
aria-label="More Admissions pages">
</button>
<ul id="id_admissions_menu" style="display:none">
<li>
<a href="#mythical-page-content">
Apply
</a>
</li>
<li>
<a href="#mythical-page-content">
Tuition
</a>
</li>
<li>
<a href="#mythical-page-content">
Sign Up
</a>
</li>
<li>
<a href="#mythical-page-content">
Visit
</a>
</li>
<li>
<a href="#mythical-page-content">
Photo Tour
</a>
</li>
<li>
<a href="#mythical-page-content">
Connect
</a>
</li>
</ul>
</li>
<li>
<a href="#mythical-page-content" class="main-link">
Academics
</a>
<button type="button"
aria-expanded="false"
aria-controls="id_academics_menu"
aria-label="More Academics pages">
</button>
<ul id="id_academics_menu" style="display:none">
<li>
<a href="#mythical-page-content">
Colleges & Schools
</a>
</li>
<li>
<a href="#mythical-page-content">
Programs of Study
</a>
</li>
<li>
<a href="#mythical-page-content">
Honors Programs
</a>
</li>
<li>
<a href="#mythical-page-content">
Online Courses
</a>
</li>
<li>
<a href="#mythical-page-content">
Course Explorer
</a>
</li>
<li>
<a href="#mythical-page-content">
Register for Class
</a>
</li>
<li>
<a href="#mythical-page-content">
Academic Calendar
</a>
</li>
<li>
<a href="#mythical-page-content">
Transcripts
</a>
</li>
</ul>
</li>
</ul>
</nav>
<div id="mythical-page-content"
class="disclosure-page-content"
tabindex="-1"
role="region"
aria-labelledby="mythical-page-heading">
<h3 id="mythical-page-heading">
Home
</h3>
<p>
Sample content section. Activating a link above will update and navigate to this region.
</p>
</div>
<footer class="sample-footer">
Mythical University footer information
</footer>