Overview
Most web pages have an overall structure that is consistent with other web pages. For example, they tend to have a banner with branding and other high-level content, one or more lists of links for navigation within the website, a section where the main content resides, and a footer. Many pages also have a sidebar with complementary content, and a section of the page dedicated to search. All users benefit from a consistent, predictable page structure as it helps them to easily find content that typically can be found within these page regions.
For sighted users, page regions can easily be located by visual cues. They are typically positioned in predictable places, and often have a background color or border that differentiates them from surrounding content.
Screen reader users need to understand the page structure just like everyone else. If page regions are coded properly, screen reader users can understand the overall structure of the page, and can easily jump directly to a specific page region. There are two methods for coding web pages in a way that explicitly identifies these common page regions. Both are described on the Techniques page, linked in the following section.
Techniques
HTML semantic elements
Starting with HTML5, the HTML specification includes several elements that identify common regions of the page. See below for a table of relevant HTML elements and their corresponding ARIA Landmark roles.
ARIA landmark roles
ARIA is a W3C specification that stands for “Accessible Rich Internet Applications”. Its overall purpose is more fully described on the IT Accessibility Checklist page titled ARIA. It includes a set of role attributes that can be used to identify common regions of the page. In general, these are the same page regions that can be identified using HTML semantic elements.
HTML vs ARIA: Which to use?
ARIA Landmark roles came first, and were supported by assistive technologies before HTML5 semantic elements were. However, that was well over a decade ago, and assistive technologies have supported both methods for many years. Therefore, it is always best to use HTML first, and turn to ARIA only as a last resort.
An example of why you might use ARIA Landmark roles is if you’re retrofitting a legacy website for accessibility, and it uses non-semantic HTML elements such as <div> as the outer containers for common page regions. Depending on the website, changing <div> to a semantic element such as <nav> (for a navigation region) or <main> (for the main region) might be disruptive, if the site’s CSS and JavaScript are dependent on the original code. In that case, adding ARIA role="navigation" or role="main" to the <div> elements has the same effect for screen reader users, and is not at all disruptive.
Mapping of HTML elements to ARIA landmark roles
| HTML Element | ARIA Landmark Role | Description | 
|---|---|---|
| <aside> | complementary | A sidebar, content that is peripheral to the main content | 
| <footer> | contentinfo | Footer of the page | 
| <header> | banner | Banner of the page | 
| <main> | main | Main content of the page | 
| <nav> | navigation | Website navigation, links to other pages | 
In addition, <form> (or role="form") and <section> (or role="region") are handled by some screen readers in the same way as other page regions if they have aria-labelledby, aria-label, or title attributes.
Additional details about these mappings are available on the W3C’s HTML Sectioning Elements page.
Label any region that is used more than once
If any region is used more than once on a page, the aria-label or aria-labelledby attribute should also be used in order to distinguish between the regions. For example, it is common for web pages to have multiple navigation regions. These might be differentiated as follows:
- <nav aria-label=”Quick links”>
- <nav aria-label=”Audience menu”>
- <nav aria-label=”Social”>
Avoid role=”application”
One ARIA Landmark role that has no corresponding HTML counterpart is role="application". This can be used to identify a very dynamic and desktop-like web application. When this role is used, there is an expectation that the application has its own model for navigating and operating all controls by keyboard and help text is easily available so users can learn the keystrokes. When assistive technologies encounter content that’s marked with this role, they essentially stop listening for users’ keystrokes and hand off all functionality to the application. This can be problematic as it defies users’ expectations, and therefore should be used only in rare instances where the web application has been carefully developed with accessibility in mind, and steps have been taken to inform users of what to expect and how to use it.
WCAG 2.1 success criteria
The issues described on this page, and associated Techniques pages, map to the following success criteria in the W3C’s Web Content Accessibility Guidelines (WCAG) 2.1:
- 1.3.1 Info and Relationships (Level A)
- 2.4.1 Bypass Blocks (Level A)