Layout Grid Examples
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 following examples demonstrate how the Grid Pattern can be used to group a collection of interactive widgets into a single tab stop. In these examples, each widget, such as a link or button, is in a separate cell of the grid, and the user can navigate between them with the arrow keys. While navigating with the arrow keys, widgets receive keyboard focus and can be activated with Space or Enter.
In addition to streamlining keyboard interfaces, these grids also convey logical grouping and semantic relationships for the elements they contain. For people who can see the screen, these groupings and relationships are visually communicated with layout and other elements of the visual design. And, by navigating the logical structure that a grid widget provides, screen reader users are also able to easily perceive the same semantic relationships.
The distinguishing feature of grid
that enables it to be used for grouping other widgets is that its cells are containers that preserve the semantics of their descendant elements.
That is, grid cells do not override or suppress the semantics of the elements they contain.
Thus, a link contained inside of a grid cell is presented to a screen reader as a link.
By contrast, a link inside of a menu is presented as a menuitem, and a link inside of a listbox is presented as an option.
Similar examples include:
- Data Grid Examples: Three example implementations of grid that include features relevant to presenting tabular information, such as content editing, sort, and column hiding.
- Advanced Data Grid Example: Example of a grid with behaviors and features similar to a typical spreadsheet, including cell and row selection.
Examples
Example 1: Simple List of Links
This example presents a list of links titled "Related Documents" in a grid.
Related Documents
Notes
-
This grid includes three features to enhance perception of the availability of arrow key navigation:
- The focus indicator changes to a dotted blue box.
- When screen size is sufficiently large, A graphic of an arrow keypad appears in the page gutter on the bottom left.
-
The first time a user moves focus into the grid with Tab, a
NUX
(new user experience helper) appears in the page tab sequence immediately following the grid. The NUX explains the meaning of the focus indicator and keypad graphic, and it remains visible until the user closes it.
- This grid is useful in a responsive design. It dynamically adjusts the number of cells per row based on screen size. As the grid structure changes, the arrow key behavior adjusts accordingly.
- Since all of the links are part of a single logical group, repeatedly pressing either Down Arrow or Right Arrow will move focus through all links in different sequences that depend on the visual arrangement.
- The Left Arrow and Up Arrow keys reverse Right Arrow and Down Arrow focus movement, respectively.
- The Home and End keys will move focus to the first and last links, respectively.
- The Page Down and Page Up keys are not supported since scrolling or row skipping functions are not needed with so few rows.
- The links can be activated with the keyboard when focused.
Example 2: Pill List For a List of Message Recipients
Add recipients by typing a string in the "New Recipient Name" field and pressing Enter or activating the "Add" button. See how this grid behaves as the number of elements increases.
Notes
-
This grid demonstrates that logical rows do not have to be vertically stacked.
- Each logical row has two cells: one containing a recipient name link and one containing the remove icon for that recipient.
- There are multiple logical rows arranged in a line across the screen.
- As the number of recipients grows, new elements wrap to additional lines as needed.
- Down Arrow and Up Arrow move to the next and previous logical row.
- So for example, Down Arrow can move focus from recipient to recipient or from remove icon to remove icon.
- Like in example 1, Right Arrow can move focus to every element from beginning to end and vice versa with the Left Arrow.
- Pressing Enter when focus is in the add recipient input will activate the "Add" button.
- When recipients are added or removed, an off-screen live region informs screen reader users of the result of the action so they do not have to move focus to confirm that the action was completed.
Example 3: Scrollable Search Results
This example demonstrates how a grid can make moving through an infinitely large data set as easy and efficient for keyboard users as it is for mouse users. It presents a hypothetical set of search results for W3C resources about WAI-ARIA.
Search Results for "W3C WAI-ARIA"
Notes
- This example shows how a logical row can span multiple physical rows. All three cells for each result are in a row, and that row occupies multiple visual rows on the screen.
- In addition to the navigation keys supported in examples 1 and 2, Page Down and Page Up scroll the grid.
-
As navigating up or down scrolls the visible set of rows, the
aria-rowindex
value of the row containing focus informs assistive technologies of the number of that row within the total set of rows.
Other Features
This implementation of grid allows the following focus movement behaviors to be declared in the HTML.
- Whether to focus a cell or an element inside it when the cell is clicked or a navigation key is pressed:
- The section of the grid pattern on Setting Focus and Navigating Inside Cells describes how to design the focus placement strategy.
- Whether focus can wrap from the last column to the first column in the next row or from the first column to the last column in the previous row when Right Arrow and Left Arrow are pressed:
- This wrapping is expected in all grids except for those presenting tabular, i.e., spreadsheet-like, data. The data grid examples demonstrate grids where focus movement does not wrap at the ends of rows.
- Whether focus can wrap to the first row in the next column or the last row in the previous column when Down Arrow and Up Arrow are pressed:
- The only condition where this wrapping is appropriate is when every cell in the grid belongs to a single logical set. In other words, if presentation of all elements in a single row is logically equivalent to presenting the same elements in an arbitrary number of rows and columns, then it is appropriate for Down Arrow and Up Arrow to behave as if all cells are in a single column. For instance, in example 1, all cells contain a navigation link. That set of six links could be presented in a single row, a single column, or divided into two rows of three or three rows of two; all these presentations would be logically equivalent. Conversely, in example 3, each logical row contains three cells, and it would be bizarre for the focus to move from the last search result link to the organization cell of the first search result when Down Arrow is pressed.
The example JavaScript allows the desired focus placement and wrapping behavior to be declared in the HTML content as follows.
-
If a cell has
tabindex="-1"
, focus is placed on the cell. Otherwise, it is placed on a focusable element inside the cell. -
To determine whether arrow key events should wrap focus movement, the example JavaScript looks for the following custom data attributes:
-
data-wrap-cols="true"
: When this custom data attribute is on the grid, Right Arrow and Left Arrow move focus from column to column even across row boundaries to the column (cell) in the next or previous row. Setting itfalse
will disable this type of wrapping. -
data-wrap-rows="true"
: When this custom data attribute is on the grid, Down Arrow and Up Arrow move focus from row to row even across column boundaries to the row (cell) in the next or previous column. Setting itfalse
will disable this type of wrapping.
-
Keyboard Support
NOTE: The following table describes keyboard commands that move focus among grid cells. In the examples on this page, some cells contain a single focusable widget, and if a cell contains a widget, the cell is not focusable; the widget receives focus instead of the cell. So, when a description says a command moves focus to a cell, the command may either focus the cell or a widget inside the cell.
Key | Function |
---|---|
Right Arrow |
|
Left Arrow |
|
Down Arrow |
|
Up Arrow |
|
Page Down (Example 3) |
|
Page Up (Example 3) |
|
Home | Moves focus to the first cell in the row that contains focus. |
End | Moves focus to the last cell in the row that contains focus. |
Control + Home | Moves focus to the first cell in the first row. |
Control + End | Moves focus to the last cell in the last row. |
Role, Property, State, and Tabindex Attributes
Role | Attribute | Element | Usage |
---|---|---|---|
grid |
div |
|
|
aria-labelledby="ID_REF"
|
div |
Refers to the element that labels the grid. | |
aria-rowcount="19" |
div |
|
|
row |
div |
|
|
aria-rowindex="INDEX_VALUE" |
div |
|
|
gridcell |
span, div |
Identifies the element containing the content for a single cell. | |
tabindex="-1" |
span, div |
|
|
tabindex="-1" |
Widgets inside cells |
|
|
tabindex="0" |
span, div, or if present, widget inside cell |
|
JavaScript and CSS Source Code
- CSS:
- JavaScript:
HTML Source Code
Example 1: Simple List of Links
<h4 id="grid1_label">
Related Documents
</h4>
<div id="ex1-grid"
role="grid"
class="list-links"
aria-labelledby="grid1_label"
data-wrap-cols="true"
data-wrap-rows="true"
data-restructure="true">
<div role="row">
<span role="gridcell" class="list-link">
<a tabindex="-1" href="http://www.w3.org/TR/wai-aria-1.1/">
ARIA 1.1 Specification
</a>
</span>
<span role="gridcell" class="list-link">
<a tabindex="-1" href="https://www.w3.org/TR/core-aam-1.1/">
Core Accessibility API Mappings 1.1
</a>
</span>
<span role="gridcell" class="list-link">
<a tabindex="-1" href="https://www.w3.org/WAI/intro/aria.php">
WAI-ARIA Overview
</a>
</span>
<span role="gridcell" class="list-link">
<a tabindex="-1" href="https://www.w3.org/WAI/intro/wcag">
WCAG Overview
</a>
</span>
<span role="gridcell" class="list-link">
<a tabindex="-1" href="https://html.spec.whatwg.org/">
HTML Specification
</a>
</span>
<span role="gridcell" class="list-link">
<a tabindex="-1" href="https://www.w3.org/TR/SVG2/">
SVG 2 Specification
</a>
</span>
</div>
</div>
<div id="grid-nux"
class="grid-nux hidden"
role="region"
aria-label="Grid Instructions"
tabindex="0">
<p class="grid-nux-header">
Move keyboard focus inside a grid with arrow keys.
</p>
<p class="indicator_description">
<img src="../../../../../../content-images/wai-aria-practices/patterns/grid/examples/imgs/black_keys.png"
width="100"
alt="Arrow keypad"
class="indicator_graphic">
</p>
<p>
This focus ring means arrow key navigation is available.
Press arrow keys to move inside the component.
Press Tab to jump to the next component.
<span class="indicator_description">
As a reminder, an arrow keypad graphic also appears in the lower left corner of the page.
</span>
</p>
<p>
Components that support arrow keys often enable additional keys that make navigation easier, such as Home, End, Ctrl-Home, Ctrl-End, Page Up, and Page Down.
</p>
<a id="close-nux-button"
class="close-nux-button"
role="button"
tabindex="0">
Close Tutorial
</a>
</div>
Example 2: Pill List For Components Like a List of Message Recipients
<div class="recipient-list">
<span id="send_to_label">
Send To:
</span>
<div id="ex2-grid"
role="grid"
class="pill-list"
aria-labelledby="send_to_label"
data-wrap-cols="true">
<div role="row"
class="pill-item"
data-id="1">
<span role="gridcell">
<a id="r1"
class="pill-name"
tabindex="-1"
href="#">
Recipient Name 1
</a>
</span>
<span role="gridcell">
<span id="rb1"
class="pill-remove"
tabindex="-1"
role="button"
aria-label="Remove"
aria-labelledby="rb1 r1">
X
</span>
</span>
</div>
<div role="row"
class="pill-item"
data-id="2">
<span role="gridcell">
<a id="r2"
class="pill-name"
tabindex="-1"
href="#">
Recipient Name 2
</a>
</span>
<span role="gridcell">
<span id="rb2"
class="pill-remove"
tabindex="-1"
role="button"
aria-label="Remove"
aria-labelledby="rb2 r2">
X
</span>
</span>
</div>
</div>
<div id="recipient-form">
<input id="add-recipient-input"
type="text"
aria-label="Add Recipient"
placeholder="New Recipient Name">
<button type="button" id="add-recipient-button">
Add
</button>
<div class="accessible_elem">
Last change to recipient list:
<span aria-live="polite"
aria-relevant="text"
id="form-action-text"></span>
</div>
</div>
</div>
Example 3: Scrollable Search Results
<h4 id="ex3_search_results_label">
Search Results for "W3C WAI-ARIA"
</h4>
<div class="ex3_result_indices">
Showing results
<span id="ex3_start_index">
1
</span>
to
<span id="ex3_end_index">
5
</span>
of 19
</div>
<div id="ex3-grid"
role="grid"
aria-labelledby="ex3_search_results_label"
aria-rowcount="19"
data-per-page="5"
data-wrap-cols="true">
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/WAI/intro/aria">
WAI-ARIA Overview Web Accessibility Initiative W3C
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
WAI-ARIA, the Accessible Rich Internet Applications Suite, defines a way to make Web content and Web applications more accessible to people with disabilities.
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/TR/wai-aria-1.0/states_and_properties">
ARIA States and Properties - W3C
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
In this document, states and properties are both treated as aria-prefixed markup attributes. However, they are maintained conceptually distinct to clarify subtle ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/TR/wai-aria/">
Accessible Rich Internet Applications (WAI-ARIA) 1.0 - W3C
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
Mar 20, 2014 - This is the WAI-ARIA 1.0 W3C Recommendation from the Protocols & Formats Working Group of the Web Accessibility Initiative. The Working ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/WAI/ARIA/">
Accessible Rich Internet Applications (ARIA) Working Group - W3C
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
The mission of the Accessible Rich Internet Applications Working Group (ARIA WG) is to develop technologies that enhance accessibility of web content for ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/TR/wai-aria-1.1/">
Accessible Rich Internet Applications (WAI-ARIA) 1.1 - W3C
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
Jul 21, 2016 - This version of ARIA 1.1 changes the aria-kbdshortcuts property to aria-keyshortcuts , expands roles that can be used in comboboxes, adds a ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/TR/wai-aria-1.0/roles">
The Roles Model | Accessible Rich Internet Applications (WAI-ARIA) 1.0
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
This section defines the WAI-ARIA role taxonomy and describes the characteristics and properties of all roles. A formal RDF / OWL representation of all the ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/TR/wai-aria-practices-1.1/">
WAI-ARIA Authoring Practices 1.1 - W3C
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
Mar 17, 2016 - The WAI-ARIA Authoring Practices Guide is intended to provide an understanding of how to use WAI-ARIA to create an accessible Rich Internet ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/TR/html-aria/">
ARIA in HTML - W3C
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
Oct 5, 2016 - ARIA in HTML is a [ HTML51 ] specification module. Any HTML features, conformance requirements, or terms that this specification module ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/TR/html-aria/">
ARIA in HTML
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
Jul 24, 2015 - Setting an ARIA role and/or aria-* attribute that matches the default implicit ARIA semantics is unnecessary and is NOT RECOMMENDED as ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/WAI/standards-guidelines/aria/">
Accessible Rich Internet Applications (ARIA) Overview
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
Here are answers to some frequently asked questions (FAQ) about WAI-ARIA, the Accessible Rich Internet Applications Suite. When we add significant ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/TR/wai-aria-implementation/">
WAI-ARIA 1.0 User Agent Implementation Guide - W3C
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
WAI-ARIA enables rich Internet applications to have the same accessibility features as desktop GUI applications by adding metadata to markup technologies ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://w3c.github.io/html-reference/aria/aria.html">
ARIA - HTML5 - W3C on GitHub
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
Alertdialog #. aria.alertdialog = role="" alertdialog "" intermixed with an optional aria-expanded element. Application #. aria.application = role="" application ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/WAI/PF/aria-practices/">
WAI-ARIA 1.0 Authoring Practices - W3C
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
Abstract. This document provided readers with an understanding of how to use WAI-ARIA [ ARIA ] to create accessible rich internet applications. It described ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/TR/aria-in-html/">
Notes on Using ARIA in HTML - W3C
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
May 21, 2015 - This document demonstrates how to use WAI-ARIA in [ HTML51 ], which especially helps with dynamic content and advanced user interface ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/standards/techs/aria">
Accessible Rich Internet Applications (WAI-ARIA) Current Status - W3C
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
Accessible Rich Internet Applications (WAI-ARIA) 1.0. Accessibility of Web content to people with disabilities requires semantic information about widgets, ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/WAI/PF/aria/">
Accessible Rich Internet Applications (WAI-ARIA) 1.0 - W3C
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
Feb 3, 2014 - This version: http://www.w3.org/WAI/PF/aria/; Previous editors' draft: ... This document is part of the WAI-ARIA suite described in the WAI-ARIA ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/TR/wai-aria-1.0/introduction">
Introduction | Accessible Rich Internet Applications (WAI-ARIA) 1.0
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
WAI-ARIA is a technical specification that provides a framework to improve the accessibility and interoperability of web content and applications. This document ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/TR/wai-aria-1.0/usage">
Using WAI-ARIA | Accessible Rich Internet Applications (WAI-ARIA) 1.0
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
WAI-ARIA divides the semantics into roles (the type defining a user interface element) and states and properties supported by the roles. Authors need to ...
</span>
</div>
<div role="row">
<div role="gridcell">
<h5 class="ex3_result_header">
<a tabindex="-1" href="https://www.w3.org/TR/WCAG20-TECHS/aria#ARIA11">
Using ARIA landmarks to identify regions of a page - WCAG WG - W3C
</a>
</h5>
</div>
<span tabindex="-1" role="gridcell">
World Wide Web Consortium
</span>
<span tabindex="-1" role="gridcell">
Jan 3, 2014 - NVDA 2 supports all landmarks except it will not support navigation to “application”; Window Eyes as of V.7 does not support ARIA landmarks.
</span>
</div>
</div>
<div class="ex3_pagination">
<button type="button"
disabled=""
id="ex3_pageup_button">
Previous
</button>
<button type="button" id="ex3_pagedown_button">
Next
</button>
</div>