Web Components Grid Keyboard Navigation
The Ignite UI for Web Components Keyboard Navigation feature in Web Components Grid provides a rich variety of keyboard interactions for the user. It enhances the accessibility of the IgcGridComponent
and allows the user to navigate through any type of elements inside (cell, row, column header, toolbar, footer, etc.). This functionality is enabled by default, and the developer has the option to override any of the default behaviors in an easy way.
The tabulations of the IgcGridComponent
has been reduced so that the navigation is compliant with W3C accessibility standards and convenient to use.
Currently, the IgcGridComponent
introduces the following tab stops:
- GroupBy or Toolbar area (if enabled).
- Grid header.
- Grid body.
- Column summaries (if enabled).
- Grid paginator (if enabled).
[!Note] Due to this change, navigating between the cells with tab and Shift + Tab is no longer supported in the
IgcGridComponent
. Pressing the Tab key now goes through the tab stops in the following order: GroupBy / Toolbar -> Headers -> Body -> Summaries -> Footer / Paginator.
[!Note] Exposing any focusable element into the
IgcGridComponent
body via template may introduce side effects in the keyboard navigation, since the default browser behavior is not prevented. It is the developer's responsibility to prevent or modify it appropriately.
Header Navigation
A full keyboard navigation support in the IgcGridComponent
header is now introduced. Column headers can be easily traversed with the arrow keys. Additionally, there are a number of key combinations that trigger actions on the columns like filtering, sorting, grouping and etc.
When the IgcGridComponent
header container is focused, the following key combinations are available:
Key Combinations
- ↑ navigates one cell up in the headers (no looping). Available only when Multi-row Layout (MRL) or Multi-column Headers (MCH) are defined.
- ↓ navigates one cell down in the headers (no wrapping). Available only when Multi-row Layout (MRL) or Multi-column Headers (MCH) are defined.
- ← navigates one cell left (no looping).
- → navigates one cell right (no wrapping between lines).
- Ctrl + ← navigates to the leftmost cell in the row; if MRL or MCH are enabled, navigates to the leftmost cell at the same level.
- Home navigates to the leftmost cell in the row; if MRL or MCH are enabled, navigates to the leftmost cell at the same level.
- Ctrl + → navigates to the rightmost cell in row; if MRL or MCH are enabled, navigates to the rightmost cell at the same level.
- End navigates to the rightmost cell in row; if MRL or MCH are enabled, navigates to the rightmost cell at the same level.
- Alt + L opens Advanced Filtering dialog if Advanced Filtering is enabled.
- Ctrl + Shift + L opens the Excel Style Filter dialog or the default (row) filter if the column is filterable.
- Ctrl + ↑ sorts the active column header in ASC order. If the column is already sorted in ASC, sorting state is cleared.
- Ctrl + ↓ sorts the active column header in DSC order. If the column is already sorted in DSC, sorting state is cleared.
- Space selects the column. If the column is already selected, selection is cleared.
- Shift + Alt + ← groups the column, if the column is marked as groupable.
- Shift + Alt + → ungroups the column, if the column is marked as groupable.
- Alt + ← or Alt + ↑ collapses the column group header, if the header is not already collapsed.
- Alt + → or Alt + ↓ expands the column group header, if the header is not already expanded.
Body navigation
When the IgcGridComponent
body is focused, the following key combinations are available:
Key Combination
- ↑- navigates one cell up.
- ↓ navigates one cell down.
- ← navigates one cell left (no wrapping between lines).
- → - navigates one cell right (no wrapping between lines).
- Ctrl + ← navigates to the leftmost cell in the row.
- Ctrl + → navigates to the rightmost cell in the row.
- Ctrl + ↑ navigates to the first cell in the column.
- Ctrl + ↓ navigates to the last cell in the column.
- Home navigates to the leftmost cell in the row.
- End navigates to the rightmost cell in the row.
- Ctrl + Home navigates to the top leftmost data cell in the grid.
- Ctrl + End navigates to the bottom rightmost data cell in the grid.
- Page Up scrolls one page (view port) up.
- Page Down scrolls one page (view port) down.
- Enter enters edit mode.
- F2 enters edit mode.
- Esc exits edit mode.
- Tab available only if there is a cell in edit mode; moves the focus to the next editable cell in the row; after reaching the last cell in the row, moves te focus to the first editable cell in the next row. When Row Editing is enabled, moves the focus from the right-most editable cell to the CANCEL and DONE buttons, and from DONE button to the left-most editable cell in the row.
- Shift + Tab - available only if there is a cell in edit mode; moves the focus to the previous editable cell in the row; after reaching the first cell in the row, moves the focus to the last editable cell in the previous row. When Row Editing is enabled, moves the focus from the right-most editable cell to CANCEL and DONE buttons, and from DONE button to the right-most editable cell in the row.
- Space - selects the row, if Row Selection is enabled.
- Alt + ← or Alt + ↑ -
over Group Row - collapses the group.
- Alt + → or Alt + ↓ - over Group Row - expands the group.
- Alt + ← or Alt + ↑ - over Master Detail Row - collapses the details view.
- Alt + → or Alt + ↓ - over Master Detail Row - expands the details view.
- Space - over Group Row - selects all rows in the group, if
RowSelection
property is set to multiple.
Practice all of the above mentioned actions in the demo sample below. Focus any navigable grid element and a list with some of the available actions for the element will be shown to guide you through.
Demo
Custom Keyboard Navigation
Overriding the default behavior for a certain key or keys combination is one of the benefits that the Keyboard Navigation feature provides. For example: press the Enter or Tab key to navigate to the next cell or the cell below. This or any other navigation scenario is easily achieved by the Keyboard Navigation API:
API | Description | Arguments |
---|---|---|
GridKeydown |
An event that is emitted when any of key press/combinations described above is performed. Can be canceled. For any other key press/combination, use the default onkeydown event. |
IgcGridKeydownEventArgs |
ActiveNodeChange |
An event that is emitted when the active node is changed. You can use it to determine the Active focus position (header, tbody etc.), column index, row index or nested level. | IgcActiveNodeChangeEventArgs |
NavigateTo |
Navigates to a position in the grid, based on provided Rowindex and VisibleColumnIndex . It can also execute a custom logic over the target element, through a callback function that accepts param of type { targetType: GridKeydownTargetType, target: Object } . Usage: grid.navigateTo(10, 3, (args) => { args.target.nativeElement.focus(); }); |
RowIndex: number, VisibleColumnIndex: number, callback: ({ targetType: GridKeydownTargetType, target: Object } ) => {} |
GetNextCell |
returns ICellPosition object, which defines the next cell by RowIndex and VisibleColumnIndex . A callback function can be passed as a third parameter of GetNextCell method. The callback function accepts IgcColumnComponent as a param and returns a boolean value indication if a given criteria is met: const nextEditableCell = grid.getNextCell(0, 4, (col) => col.editable); |
currentRowIndex: number, currentVisibleColumnIndex: number, callback: (Column) => boolean |
GetPreviousCell |
returns ICellPosition object, which defines the previous cell by RowIndex and VisibleColumnIndex . A callback function can be passed as a third parameter of GetPreviousCell method. The callback function accepts IgcColumnComponent as a param and returns a boolean value indication if a given criteria is met: const prevEditableCell = grid.getPreviousCell(0, 4, (col) => col.editable); |
CurrentRowIndex: number, CurrentVisibleColumnIndex: number, callback: (Column) => boolean |
Let's try the API to demonstrate how to achieve common scenarios like user input validation and custom navigation. First we need to register an event handler for the GridKeydown
event:
<igc-grid id="grid1" primary-key="ProductID">
</igc-grid>
constructor() {
var grid = this.grid = document.getElementById('grid') as IgcGridComponent;
grid.data = this.data
grid.addEventListener("gridKeydown", this.customKeydown);
}
Based on the event arg values we identified two cases, where to provide our own logic (see above). Now, using the methods from the API, let's perform the desired - if the user is pressing Tab key over a cell in edit mode, we will perform validation on the input. If the user is pressing Enter key over a cell, we will move focus to cell in the next row:
// 1. USER INPUT VALIDATION ON TAB
if (target.column.dataType === 'number' && target.editValue < 10) {
// alert the user that the input is invalid
return;
}
// 2. CUSTOM NAVIGATION ON ENTER KEY PRESS
this.grid1.navigateTo(target.row.index + 1, target.column.visibleIndex, (obj) => {
obj.target.activate();
});
[!Note] Please refer to the sample code for full implementation details.
Use the demo below to try out the custom scenarios that we just implemented:
- Double click or press F2 key on a cell in a numeric column, change the value to 7 and press Tab key. Prompt message will be shown.
- Select a cell and press Enter key a couple of times. Every key press will move the focus to a cell in the next row, under the same column.
Demo
Known Limitations
Limitation | Description |
---|---|
Navigating inside а grid with scrollable parent container. | If the grid is positioned inside a scrollable parent container and the user navigates to a grid cell that is out of view, parent container will not be scrolled. |
Additional Resources
- Virtualization and Performance
- Filtering
- Sorting
- Summaries
- Column Moving
- Column Pinning
- Column Resizing
- Selection
Our community is active and always welcoming to new ideas.