3.2: ¿Qué es WAI-ARIA?
- Page ID
- 152552
\( \newcommand{\vecs}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)
\( \newcommand{\vecd}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash {#1}}} \)
\( \newcommand{\id}{\mathrm{id}}\) \( \newcommand{\Span}{\mathrm{span}}\)
( \newcommand{\kernel}{\mathrm{null}\,}\) \( \newcommand{\range}{\mathrm{range}\,}\)
\( \newcommand{\RealPart}{\mathrm{Re}}\) \( \newcommand{\ImaginaryPart}{\mathrm{Im}}\)
\( \newcommand{\Argument}{\mathrm{Arg}}\) \( \newcommand{\norm}[1]{\| #1 \|}\)
\( \newcommand{\inner}[2]{\langle #1, #2 \rangle}\)
\( \newcommand{\Span}{\mathrm{span}}\)
\( \newcommand{\id}{\mathrm{id}}\)
\( \newcommand{\Span}{\mathrm{span}}\)
\( \newcommand{\kernel}{\mathrm{null}\,}\)
\( \newcommand{\range}{\mathrm{range}\,}\)
\( \newcommand{\RealPart}{\mathrm{Re}}\)
\( \newcommand{\ImaginaryPart}{\mathrm{Im}}\)
\( \newcommand{\Argument}{\mathrm{Arg}}\)
\( \newcommand{\norm}[1]{\| #1 \|}\)
\( \newcommand{\inner}[2]{\langle #1, #2 \rangle}\)
\( \newcommand{\Span}{\mathrm{span}}\) \( \newcommand{\AA}{\unicode[.8,0]{x212B}}\)
\( \newcommand{\vectorA}[1]{\vec{#1}} % arrow\)
\( \newcommand{\vectorAt}[1]{\vec{\text{#1}}} % arrow\)
\( \newcommand{\vectorB}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)
\( \newcommand{\vectorC}[1]{\textbf{#1}} \)
\( \newcommand{\vectorD}[1]{\overrightarrow{#1}} \)
\( \newcommand{\vectorDt}[1]{\overrightarrow{\text{#1}}} \)
\( \newcommand{\vectE}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash{\mathbf {#1}}}} \)
\( \newcommand{\vecs}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)
\( \newcommand{\vecd}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash {#1}}} \)
\(\newcommand{\avec}{\mathbf a}\) \(\newcommand{\bvec}{\mathbf b}\) \(\newcommand{\cvec}{\mathbf c}\) \(\newcommand{\dvec}{\mathbf d}\) \(\newcommand{\dtil}{\widetilde{\mathbf d}}\) \(\newcommand{\evec}{\mathbf e}\) \(\newcommand{\fvec}{\mathbf f}\) \(\newcommand{\nvec}{\mathbf n}\) \(\newcommand{\pvec}{\mathbf p}\) \(\newcommand{\qvec}{\mathbf q}\) \(\newcommand{\svec}{\mathbf s}\) \(\newcommand{\tvec}{\mathbf t}\) \(\newcommand{\uvec}{\mathbf u}\) \(\newcommand{\vvec}{\mathbf v}\) \(\newcommand{\wvec}{\mathbf w}\) \(\newcommand{\xvec}{\mathbf x}\) \(\newcommand{\yvec}{\mathbf y}\) \(\newcommand{\zvec}{\mathbf z}\) \(\newcommand{\rvec}{\mathbf r}\) \(\newcommand{\mvec}{\mathbf m}\) \(\newcommand{\zerovec}{\mathbf 0}\) \(\newcommand{\onevec}{\mathbf 1}\) \(\newcommand{\real}{\mathbb R}\) \(\newcommand{\twovec}[2]{\left[\begin{array}{r}#1 \\ #2 \end{array}\right]}\) \(\newcommand{\ctwovec}[2]{\left[\begin{array}{c}#1 \\ #2 \end{array}\right]}\) \(\newcommand{\threevec}[3]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \end{array}\right]}\) \(\newcommand{\cthreevec}[3]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \end{array}\right]}\) \(\newcommand{\fourvec}[4]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \\ #4 \end{array}\right]}\) \(\newcommand{\cfourvec}[4]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \\ #4 \end{array}\right]}\) \(\newcommand{\fivevec}[5]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \\ #4 \\ #5 \\ \end{array}\right]}\) \(\newcommand{\cfivevec}[5]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \\ #4 \\ #5 \\ \end{array}\right]}\) \(\newcommand{\mattwo}[4]{\left[\begin{array}{rr}#1 \amp #2 \\ #3 \amp #4 \\ \end{array}\right]}\) \(\newcommand{\laspan}[1]{\text{Span}\{#1\}}\) \(\newcommand{\bcal}{\cal B}\) \(\newcommand{\ccal}{\cal C}\) \(\newcommand{\scal}{\cal S}\) \(\newcommand{\wcal}{\cal W}\) \(\newcommand{\ecal}{\cal E}\) \(\newcommand{\coords}[2]{\left\{#1\right\}_{#2}}\) \(\newcommand{\gray}[1]{\color{gray}{#1}}\) \(\newcommand{\lgray}[1]{\color{lightgray}{#1}}\) \(\newcommand{\rank}{\operatorname{rank}}\) \(\newcommand{\row}{\text{Row}}\) \(\newcommand{\col}{\text{Col}}\) \(\renewcommand{\row}{\text{Row}}\) \(\newcommand{\nul}{\text{Nul}}\) \(\newcommand{\var}{\text{Var}}\) \(\newcommand{\corr}{\text{corr}}\) \(\newcommand{\len}[1]{\left|#1\right|}\) \(\newcommand{\bbar}{\overline{\bvec}}\) \(\newcommand{\bhat}{\widehat{\bvec}}\) \(\newcommand{\bperp}{\bvec^\perp}\) \(\newcommand{\xhat}{\widehat{\xvec}}\) \(\newcommand{\vhat}{\widehat{\vvec}}\) \(\newcommand{\uhat}{\widehat{\uvec}}\) \(\newcommand{\what}{\widehat{\wvec}}\) \(\newcommand{\Sighat}{\widehat{\Sigma}}\) \(\newcommand{\lt}{<}\) \(\newcommand{\gt}{>}\) \(\newcommand{\amp}{&}\) \(\definecolor{fillinmathshade}{gray}{0.9}\)Definición W3C de WAI-ARIA
“WAI-ARIA proporciona un marco para agregar atributos para identificar características para la interacción del usuario, cómo se relacionan entre sí y su estado actual”.
Fuente: W3C
WAI-ARIA proporciona a los autores web lo siguiente:
- Roles para describir el tipo de widget presentado, como “menu”, “treeitem”, “slider” y “progressmeter”
- Funciones para describir la estructura de la página web, como encabezados, regiones y tablas (cuadrículas)
- Las propiedades para describir los widgets de estado están en, como “marcada” para una casilla de verificación, o “haspopup” para un menú.
- Propiedades para definir regiones activas de una página que probablemente obtengan actualizaciones (como cotizaciones de acciones), así como una política de interrupción para esas actualizaciones; por ejemplo, las actualizaciones críticas pueden presentarse en un cuadro de diálogo de alerta y las actualizaciones incidentales ocurren dentro de la página
- Propiedades para arrastrar y soltar que describen las fuentes de arrastre y los destinos de caída
- Una forma de proporcionar navegación por teclado para los objetos y eventos web, como los mencionados anteriormente
Fuente: W3C
Algunos elementos del marco se pueden usar por sí mismos para agregar accesibilidad al contenido web (por ejemplo, puntos de referencia). Más a menudo, se combinan con secuencias de comandos que se utilizan para agregar o eliminar dinámicamente atributos WAI-ARIA dependiendo del contexto.
WAI-ARIA proporciona semántica para widgets personalizados y aplicaciones web que pueden ser entendidas por tecnologías de asistencia (AT) y transportadas a los usuarios en una forma “humana comprensible”. Por ejemplo, el marcado de lista HTML podría usarse para crear una barra de navegación con menús y submenús. Sin WAI-ARIA un lector de pantalla simplemente reconocería la barra de navegación como una colección de listas anidadas. Agregar atributos de menú WAI-ARIA (por ejemplo, barra de menú, menú, menuitem, aria-haspopup, aria-expanded) puede dar a la lista anidada un significado completamente nuevo, entendiéndose más fácilmente como un medio de navegación de lo que se entendería la lista.
Definición W3C de semántica
“El significado de algo tal como lo entiende un humano, definido de manera que las computadoras puedan procesar una representación de un objeto, como elementos y atributos, y representar de manera confiable al objeto de manera que varios humanos logren un entendimiento mutuamente consistente del objeto.”
Fuente: W3C
Esta definición de semántica en la programación es muy parecida a la definición común de la palabra: “el significado, o una interpretación del significado” (dictionary.com). La semántica en el contexto de la accesibilidad web se refiere a la definición del significado tal como se aplica a los elementos funcionales del contenido web, y cómo esa funcionalidad se trasmite a los usuarios de tecnología de asistencia, especialmente a los usuarios de lectores de pantalla.
Cuándo y cuándo no usar WAI-ARIA
Se supone que WAI-ARIA se usa cuando se requiere semántica para hacer comprensible una aplicación web o widget. Por ejemplo, si estás usando <div>a para crear una casilla de verificación, junto con algunas secuencias de comandos puedes asignarle la “casilla de verificación” del rol WAI-ARIA
<div>para que aparezca como una casilla de verificación.
Dicho esto, sin embargo, cuando hay un elemento HTML nativo disponible, como una casilla de verificación, casi siempre es mejor usar la versión nativa que crear la suya propia. La versión nativa ya tendrá toda la semántica asociada por defecto. Dado que las versiones nativas están estandarizadas, es más probable que sean compatibles con todos los navegadores y tecnologías de asistencia.
Para los elementos HTML nativos, no es necesario usar WAI-ARIA. Para un <form>elemento HTML, por ejemplo, no es necesario incluir
role="form”
con el elemento. Sin embargo, hay algunas excepciones a esta regla. Para algunos de los elementos HTML5 más nuevos, como <nav>y
<main>por ejemplo, no está de más incluir el equivalente de WAI-ARIA
role="navigation”
y role="main”
en estos elementos por el momento, para acomodar parte del soporte inconsistente para estos elementos a través de navegadores y AT. Los validadores HTML aún le darán advertencias sobre los roles redundantes, pero puede ignorarlos de manera segura.
También debes tener cuidado al usar WAI-ARIA con elementos HTML que ya tienen semántica. Por ejemplo, si usas <h3 role="button">algo</h3>
, se anulará la semántica asociada al encabezado, de esta manera, potencialmente rompiendo la estructura de un documento. En un caso como este, un mejor enfoque sería envolver el encabezado en un <div>entonces asignar
role="button”
al para <div>preservar la semántica estructural del encabezado, como se ve en los ejemplos a continuación.