Los elementos HTML estándar como <button>
o <input>
participan en la navegación secuencial del teclado de forma accesible. Sin embargo, si estás creando componentes interactivos personalizados utilizatabindex
para asegurarte de que sean accesibles desde el teclado.
Comprueba si tus controles son accesibles desde el teclado
Una herramienta como Lighthouse es excelente para detectar ciertos problemas de accesibilidad, pero algunas cosas solo pueden ser probadas por humanos.
Intenta presionar Tab
para navegar por tu sitio. ¿Puedes acceder a todos los controles interactivos de la página? De lo contrario, es posible que tengas que utilizar tabindex
para mejorar la capacidad de enfoque de esos controles.
Inserta un elemento en el orden de pestañas
Inserta un elemento en el orden natural de pestañas usando tabindex="0"
. Por ejemplo:
<div tabindex="0">Focus me with the TAB key</div>
Para enfocar un elemento, presiona Tab
o llama al método focus()
.
Elimina un elemento del orden de pestañas
Elimina un elemento usando tabindex="-1"
. Por ejemplo:
<button tabindex="-1">Can't reach me with the TAB key!</button>
Esto elimina un elemento del orden natural de pestañas, pero el elemento aún se puede enfocar llamando a su método focus()
.
Tené en cuenta que aplicar tabindex="-1"
a un elemento no afecta a sus elementos secundarios; si están en el orden de pestañas de forma natural o debido a un tabindex
de tabulación, permanecerán en el orden de pestañas. Para eliminar un elemento y todos sus elementos secundarios del orden de tabulación, considera usar el polyfill WICG inert
. El polyfill emula el comportamiento del atributo propuesto inert
, que evita que los elementos sean seleccionados o leídos por tecnologías de asistencia.
Evita tabindex > 0
Cualquier tabindex
mayor que 0 salta el elemento al frente del orden de tabulación natural. Si hay varios elementos con un tabindex
mayor que 0, el orden de tabulación comienza desde el valor más bajo mayor que cero y avanza hacia arriba.
El uso de un tabindex
mayor que 0 se considera un anti-patrón porque los lectores de pantalla navegan por la página en orden DOM, no en orden de tabulación. Si necesitas que un elemento aparezca antes en el orden de tabulación, debe moverse a un lugar anterior en el DOM.
Lighthouse facilita la identificación de elementos con un tabindex
> 0. Ejecuta la Auditoría de accesibilidad (Lighthouse> Opciones> Accesibilidad) y busque los resultados de la auditoría "Ningún elemento tiene un valor [tabindex] mayor que 0".
Crea componentes accesibles con "roving tabindex
" o "tabindex itinerante"
Si estás construyendo un componente complejo, es posible que necesites añadir soporte adicional para el teclado más allá del enfoque. Considera el elemento select
incorporado. Es enfocable y puede usar las teclas de flecha para exponer funcionalidades adicionales (las opciones seleccionables).
Para implementar una funcionalidad similar en sus propios componentes, utiliza una técnica conocida como " tabindex
itinerante". El tabindex itinerante o roving tabindex funciona estableciendo tabindex
en -1 para todos los elementos secundarios, excepto el que está actualmente activo. A continuación, el componente utiliza un detector de eventos de teclado para determinar qué tecla ha pulsado el usuario.
Cuando esto sucede, el componente establece el tabindex
de tabulación del elemento secundario previamente enfocado en -1, establece el tabindex
de tabulación del elemento secundario que se va a enfocar en 0 y llama al método focus()
en él.
Antes
<div role="toolbar">
<button tabindex="-1">Undo</div>
<button tabindex="0">Redo</div>
<button tabindex="-1">Cut</div>
</div>
Después
<div role="toolbar">
<button tabindex="-1">Undo</div>
<button tabindex="-1">Redo</div>
<button tabindex="0">Cut</div>
</div>
TODO: DevSite - Think and Check assessment
Fórmulas de acceso al teclado
Si no estás seguro de qué nivel de soporte de teclado pueden necesitar tus componentes personalizados, puedes consultar las Prácticas de creación de ARIA 1.1. Esta sencilla guía enumera los patrones de IU comunes e identifica qué claves deben admitir sus componentes.