layout | tags |
---|---|
doc-api.html |
argument-options |
Finds keyboard focusable ("tabbable") elements in the DOM.
See ally.query.focusable
for an explanation on the different query strategies.
Consult the data tables what browsers consider focusable and what ally.js considers focusable in strategy: "strict"
or strategy: "quick"
to learn how HTML elements behave.
var elements = ally.query.tabbable({
context: '.within-filter-selector',
includeContext: true,
strategy: 'quick',
});
Name | Type | Default | Description |
---|---|---|---|
context | <selector> |
documentElement |
The scope of the DOM in which to search. The first element of a collection is used. |
includeContext | boolean | false |
Prepend the context element if it is focusable. |
includeOnlyTabbable | boolean | false |
Include elements that would otherwise be ignored because they're considered only tabbable, |
strategy | "quick" , "strict" , "all" |
"quick" |
The approach used to find elements. |
Array of HTMLElement
.
@@@example /api/query/focusable.example.html
@@@
@@@example /api/query/tabbable.example.html
@@@
- Since
v1.1.0
the optionincludeOnlyTabbable
allows to skip the internal filter preventing this module from returning elements that cannot be focused by script.
ally.is.tabbable
is used to filter focusable elementsally.query.focusable
is used to find focusable elementsally.query.firstTabbable
finds the first keyboard focusable element in a contextally.query.tabsequence
finds keyboard focusable elements in Sequential Navigation Focus Order