React Data Grid Accessibility
Handsontable is designed to be accessible, aligning with global standards. We prioritize inclusivity, ensuring web applications are usable by people with disabilities.
Overview
Accessibility features of Handsontable include:
- Keyboard navigation that lets you use the grid without a mouse.
- Support for the most popular screen readers.
- Flexible API to configure keyboard shortcuts and navigation methods.
Conformance with standards
Most global standards and regulations are created in accordance with WCAG (Web Content Accessibility Guidelines). Handsontable meets requirements outlined in the WCAG 2.1 AA (opens new window) guidelines, which makes it compatible with most local standards such as:
United States:
Europe / European Union:
Canada:
Keyboard navigation
Handsontable does not require a mouse to navigate across the grid's elements. This is an important feature for certain users with temporary or permanent motor impairments, for whom following the tiny mouse cursor is difficult. Interestingly, some "power" users also find it easier to use the keyboard instead of the mouse.
Our experience with hundreds of implementations of Handsontable has highlighted some typical patterns. It turns out that usually Handsontable is used as either a spreadsheet application or a data grid component. While the difference may seem subtle at first, it significantly impacts user expectations regarding navigation.
In a typical spreadsheet application (think of Microsoft Excel or Google Sheets), you cannot move the focus onto headers. This makes it difficult to sort or filter data without knowing complex keyboard shortcuts. Additionally, opening a column menu is not trivial. Handsontable offers flexibility in this regard, allowing users to switch between data grid and spreadsheet "modes". To do that switch, you can use a combination of two options: navigableHeaders
to enable or disable moving focus onto headers, and tabNavigation
to decide if the Tab key can be used to navigate across cells and headers.
The following table provides more details about these two scenarios:
Aspect | Data grid mode | Spreadsheet mode (default) |
---|---|---|
Configuration options | navigableHeaders: true tabNavigation: false | navigableHeaders: false tabNavigation: true |
Primary navigation method | Arrow keys | Tab / Shift + Tab |
Description | The Arrow keys are primarily used to navigate across the grid. Use simple shortcut keys such as Enter or Space to open menus or interact with headers, cells, or cell editors. You cannot use Tab key to navigate across the grid. | The Tab key is primarily used to navigate across the grid. This behavior is similar to Excel or Google Sheets. To open menus, use more complex shortcut keys. |
Focus order | One Tab stop - the grid is included in the tab sequence within the page only once. | Multiple Tab stops - all the grid tabbable elements, such as cells or headers, are included in the page Tab sequence. |
Navigable headers | Yes | No |
Shortcut keys
Handsontable provides a wide range of shortcut keys, but some of them seem to be more important for users not using a mouse for navigation. Specifically, actions triggered while navigating across headers involve simple combinations of keyboard keys, making them intuitive and useful. For more complex scenarios, you can also customize the shortcuts keys through the API.
Windows | macOS | Action | Focused element |
---|---|---|---|
Shift + Alt + ↓ | Shift + Option + ↓ | Open a column menu | Any cell |
Ctrl + Enter | Cmd + Enter | Open a column menu | Column header |
Enter | Enter | Sort data | Column header |
Alt + A | Option + A | Clear filters | Any cell |
Ctrl + Space | Ctrl + Space * | Select a column | Any cell |
Shift + Space | Shift + Space | Select a row | Any cell |
Ctrl + Shift + \ Shift + F10 | Cmd + Shift + \ Shift + F10 | Open a context menu | Any cell |
*The keyboard shortcut for selecting an entire column, Ctrl+Space, in macOS by default selects the previous input source. To use this shortcut key in Handsontable, go to macOS settings, then Keyboard / Input Sources
and uncheck the corresponding checkbox.
Support for screen readers
Although semantic HTML doesn't need any additional attributes to be properly interpreted by assistive technologies, some of Handsontable's complex features are not fully covered by the HTML specification. That's why Handsontable provides support for screen readers with ARIA attributes (Accessible Rich Internet Applications) applied to its HTML markup.
Each new version is thoroughly tested for accessibility with the following screen readers:
- NVDA (Windows)
- JAWS (Windows)
- VoiceOver (macOS)
A demo of accessible data grid
Check out the interactive demo below to see how different Handsontable settings impact its accessibility level and affect the user experience.
High-contrast theme
The recommended minimum contrast ratio (opens new window) for text against images or backgrounds is 4.5:1. To achieve this level of contrast with Handsontable's default theme, customize it to meet your end-users' needs by applying the following actions:
- Override the grid's CSS with your own styles.
- Use third-party software, such as the High Contrast (opens new window) extension for Chrome, supported by Google.
Requirements for the developers
When you customize Handsontable, it's you who is responsible for ensuring the accessibility of your solution. Especially when you create custom cell type or custom plugin, remember about making them accessible to everyone.
Our recommendations for custom development:
- Test your code against WCAG 2.1 requirements frequently.
- Use proper color contrast, font size, and semantic HTML.
- If needed, implement additional WAI-ARIA attributes.
- Avoid flashing or blinking content.
- Test your customizations with real users who have different types of disabilities. If you don’t have access to real users, try Funkify (opens new window), a disability simulator, which can help you step into disabled users' shoes.
TIP
The quality of custom modifications in Handsontable may impact your application's accessibility level. For this reason, make sure to actively check how these changes influence the overall accessibility of your application, using tools like Lighthouse (opens new window).
Ensuring Accessibility standards
We make sure our data grid remains accessible by taking the following steps:
- We check Handsontable's accessibility score with a range of accessibility testing tools.
- We use automated visual regression testing.
- We manually test all of Handsontable's features with the most popular screen readers.
- We use automated unit and end-to-end tests.
Known limitations
- Some screen readers may incorrectly read the number of rows and columns when frozen rows and columns are enabled.
- The
aria-rowcount
attribute is intentionally set to "-1" due to most screen readers either ignoring it or misinterpreting it. This setting is particularly aimed at ensuring accuracy with screen readers like VoiceOver. We plan to revise this approach once screen readers consistently handle thearia-rowcount
attribute correctly. - Dynamic ARIA attributes are sometimes omitted by screen readers.
- When using frozen rows and columns, NVDA and JAWS may incorrectly announce the current column header, other cells remain unaffected.
API reference
For the list of options, methods, and Handsontable hooks related to accessibility, see the following API reference pages:
autoWrapCol
autoWrapRow
tabNavigation
enterBeginsEditing
enterMoves
navigableHeaders
renderAllRows
viewportColumnRenderingOffset
viewportRowRenderingOffset
Troubleshooting
Try the following links if you didn't find what you need:
- View related topics (opens new window) on GitHub
- Report an issue (opens new window) on GitHub
- Ask a question (opens new window) on Stack Overflow
- Start a discussion (opens new window) on Handsontable's forum
- Contact our technical support (opens new window) to get help