Landmark Regions
Introduction
ARIA landmark roles provide a powerful way to identify the organization and structure of a web page. By classifying and labelling sections of a page, they enable structural information that is conveyed visually through layout to be represented programmatically. Screen readers exploit landmark roles to provide keyboard navigation to important sections of a page. Landmark regions can also be used as targets for "skip links" and by browser extensions to enhanced keyboard navigation.
This section explains how HTML sectioning elements and ARIA landmark roles are used to make it easy for assistive technology users to understand the meaning of the layout of a page.
HTML Sectioning Elements
Several HTML sectioning elements automatically create ARIA landmark regions. So, in order to provide assistive technology users with a logical view of a page, it is important to understand the effects of using HTML sectioning elements. [[HTML-ARIA]] contains more information on HTML element role mapping.
| HTML Element | Default Landmark Role |
|---|---|
aside |
complementary |
footer |
contentinfo when in context of the body element |
header |
banner when in context of the body element |
main |
main |
nav |
navigation |
section |
region when it has an accessible name using aria-labelledby or aria-label |
General Principles of Landmark Design
Including all perceivable content on a page in one of its landmark regions and giving each landmark region a semantically meaningful role is one of the most effective ways of ensuring assistive technology users will not overlook information that is relevant to their needs.
Step 1: Identify the logical structure
- Break the page into perceivable areas of content which designers typically indicate visually using alignment and spacing.
- Areas can be further defined into logical sub-areas as needed.
- An example of a sub-area is a portlet in a portal application.
Step 2: Assign landmark roles to each area
- Assign landmark roles based on the type of content in the area.
banner,main,complementaryandcontentinfolandmarks should be top level landmarks.- Landmark roles can be nested to identify parent/child relationships of the information being presented.
- Note that wrapping the content of a modal dialog in a landmark region is unnecessary. A landmark that wraps modal content cannot provide any benefit to users because it is not perceivable unless the modal is open. In addition, when a modal is open, a landmark containing its content is superfluous because the modal itself is a container that provides both a name and boundaries.
Step 3: Label areas
-
If a specific landmark role is used more than once on a page, provide each instance of that landmark with a unique label.
There is one rare circumstance where providing the same label to multiple instances of a landmark can be beneficial: the content and purpose of each instance is identical.
For example, a large search results table has two sets of identical pagination controls -- one above and one below the table, so each set is in a navigation region labelled
Search Results
. In this case, adding extra information to the label that distinguishes the two instances may be more distracting than helpful. - If a landmark is only used once on the page it may not require a label. See Landmark Roles section below.
- If an area begins with a heading element (e.g.
h1-h6) it can be used as the label for the area using thearia-labelledbyattribute. - If an area requires a label and does not have a heading element, provide a label using the
aria-labelattribute. - Do not use the landmark role as part of the label. For example, a navigation landmark with a label "Site Navigation" will be announced by a screen reader as "Site Navigation Navigation". The label should simply be "Site".
Landmark Roles
Complementary
A complementary landmark is a supporting section of the document, designed to be complementary to the main content at a similar level in the DOM hierarchy, but remains meaningful when separated from the main content.
complementarylandmarks should be top level landmarks (e.g. not contained within any other landmarks).- If the complementary content is not related to the main content, a more general role should be assigned (e.g.
region). - If a page includes more than one
complementarylandmark, each should have a unique label (see Step 3 above).
HTML Technique
Use the HTML aside element to define a complementary landmark.
ARIA Technique
If the HTML aside element technique is not being used, use a role="complementary" attribute to define a complementary landmark.
Examples
Contentinfo
A contentinfo landmark is a way to identify common information at the bottom of each page within a website, typically called the "footer" of the page, including information such as copyrights and links to privacy and accessibility statements.
- Each page may have one
contentinfolandmark. - The
contentinfolandmark should be a top-level landmark. - When a page contains nested
documentand/orapplicationroles (e.g. typically through the use ofiframeandframeelements), eachdocumentorapplicationrole may have onecontentinfolandmark. - If a page includes more than one
contentinfolandmark, each should have a unique label (see Step 3 above).
HTML Techniques
- The HTML
footerelement defines acontentinfolandmark when its context is thebodyelement. -
The HTML
footerelement is not considered acontentinfolandmark when it is descendant of any of following elements (see HTML Accessibility Mappings):articleasidemainnavsection
ARIA Technique
If the HTML footer element technique is not being used, a role="contentinfo" attribute should be used to define a contentinfo landmark.
Examples
Form
A form landmark identifies a region that contains a collection of items and objects that, as a whole, combine to create a form when no other named landmark is appropriate (e.g. main or search).
- Use the
searchlandmark instead of theformlandmark when the form is used for search functionality. - A
formlandmark should have a label to help users understand the purpose of the form. - A label for the
formlandmark should be visible to all users (e.g. anh1-h6element). - If a page includes more than one
formlandmark, each should have a unique label (see Step 3 above). -
Whenever possible, controls contained in a
formlandmark in an HTML document should use native host semantics:buttoninputselecttextarea
HTML Techniques
The HTML form element defines a form landmark when it has an accessible name (e.g. aria-labelledby, aria-label or title).
ARIA Technique
Use the role="form" to identify a region of the page; do not use it to identify every form field.
Examples
Main
A main landmark identifies the primary content of the page.
- Each page should have one
mainlandmark. - The
mainlandmark should be a top-level landmark. - When a page contains nested
documentand/orapplicationroles (e.g. typically through the use ofiframeandframeelements), eachdocumentorapplicationrole may have onemainlandmark. - If a page includes more than one
mainlandmark, each should have a unique label (see Step 3 above).
HTML Technique
Use the HTML main element to define a main landmark.
ARIA Technique
If the HTML main element technique is not being used, use a role="main" attribute to define a main landmark.
Examples
Region
A region landmark is a perceivable section of the page containing content that is sufficiently important for users to be able to navigate to the section.
- A
regionlandmark must have a label. - If a page includes more than one
regionlandmark, each should have a unique label (see Step 3 above). - The
regionlandmark can be used identify content that named landmarks do not appropriately describe.
HTML Technique
The HTML section element defines a region landmark when it has an accessible name (e.g. aria-labelledby, aria-label or title).
ARIA Technique
If the HTML section element technique is not being used, use a role="region" attribute to define a region landmark.
Examples
Search
A search landmark contains a collection of items and objects that, as a whole, combine to create search functionality.
- Use the
searchlandmark instead of theformlandmark when the form is used for search functionality. - If a page includes more than one
searchlandmark, each should have a unique label (see Step 3 above).
HTML Technique
There is no HTML element that defines a search landmark.
ARIA Technique
The role="search" attribute defines a search landmark.