6.4: Acordeones
- Page ID
- 152575
\( \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}\)Los widgets de acordeón pueden venir en formatos de selección única o múltiple, en los que se pueden abrir uno o varios paneles a la vez, respectivamente. Normalmente se utilizan para reducir el espacio que ocupa el contenido y para reducir el desplazamiento. Los acordeones se componen de Cabezales de Acordeón y Paneles de Acordeón. Los encabezados de acordeón controlan la visualización de su panel de acordeón asociado.
Los roles, estados y propiedades de WAI-ARIA utilizados en un acordeón
- aria-multiseleccionable =” (true | false)”
- role=” encabezado”
- role=” botón”
- aria-controls=” [id del panel]”
- tabindex=” 0″
- role=” región”
- aria-hidden= “(true | false)”
- aria-expandida= “(true | false)”
El siguiente JSFiddle presenta un widget típico de acordeón. Revise el marcado JavaScript y HTML. Pruebe el acordeón presentado bajo la pestaña Resultado con ChromeVox para entender cómo funciona sin que se agreguen características de accesibilidad. Puedes trabajar en el propio JSFiddle haciendo clic en “Editar en JSFiddle”, copiando el código de Accesibilidad/Wai-Aria que se describe a continuación para corregir la accesibilidad del acordeón antes de completar la Actividad 9 en la página que sigue.
Primero, agregue el acordeón a las regiones marcadas asignando role="region”
al <DL>elemento de apertura cuando se inicializa el acordeón, agregando el rol region a la función
init ()
.
A continuación, agregue el atributo aria-multiseleccionable
al<DL>, que se establecerá dinámicamente en true o false según los ajustes de configuración del complemento. Esto permite al usuario saber que se puede abrir más de un panel de acordeón cuando se establece en TRUE o solo un panel cuando se establece en FALSE. Consulte el bloque
$ (document) .ready
en el HTML, donde se realiza la asignación.
<DL>También se eliminará la semántica de los hijos del elemento, al que se le asignó
role="presentation”
, su semántica de lista de definición. Agrega la semántica del acordeón role="heading”
para asignar un rol de encabezado a los <DT>elementos. El atributo
aria-level
podría usarse para implementar paneles de acordeón anidados, pero para nuestro propósito aquí es suficiente una versión simplificada.
Agrega un <div>dentro del encabezado (es decir,
DT
) y define su rol
como un botón. Al botón se le da un atributo aria-controls
para definir cuál de los paneles de acordeón controla. Por defecto el estado de alternancia se establece en false con aria-expanded="false”
para ser actualizado dinámicamente cuando se hace clic en el botón o se presiona la tecla. Finalmente agrega tabindex="0"
al botón (<div>) para que sea enfocable por teclado.
El tabindex hará que el botón sea enfocable, pero no lo hará clicable. La función.on ()
jQuery agrega un evento click al botón, pero también se debe agregar un evento de pulsación de teclas. Agregar .on ('keydown')
activa la función OnKeyDown
, definida a continuación, por lo que los encabezados de acordeón operan tanto con un clic del ratón como con una pulsación de tecla.
En la función TogklePanel ()
, antes de AutoCollapse ()
, agregue en el toggle para agregar y actualizar el atributo aria-expanded
para los encabezados del panel, en función de si el panel asociado es visible o no.
Dentro de la función AutoCollapse ()
, toggle aria-expanded="false”
y aria-hidden="true”
para todas las pestañas de acordeón que no sean las actuales. Esto asegura que solo un panel esté abierto a la vez.
Por último, se agrega la semántica del panel acordeón, definiendo los <DD>elementos a los que se eliminó su semántica cuando se agregó
role="presentation”
al padre<DL>. A los paneles se les da un
role="region”
genérico para que el panel sea navegable en la lista de hitos, configurado para que se oculte por defecto con aria-hidden="true”
para que todos los paneles se cierren cuando se carga la página. Además, también se agrega tabindex="0"
para que el teclado de los paneles sea enfocable de manera que se lea el contenido del panel a medida que el usuario navega hacia ellos.
Adición de operabilidad del teclado
Las mejores prácticas de WAI-ARIA definen todas las funcionalidades de teclado de acordeón recomendadas, enumeradas a continuación En nuestro ejemplo, solo se incluyen los eventos de teclado requeridos.
Interacción de teclado para acordeones
- Entrar o Espacio:
- Cuando el foco está en el encabezado del acordeón para un panel colapsado, expande el panel asociado. Si la implementación permite que solo se expanda un panel, y si otro panel se expande, colapsa ese panel.
- Cuando el foco está en el encabezado de acordeón para un panel expandido, colapsa el panel si la implementación admite colapsar. Algunas implementaciones requieren que un panel se expanda en todo momento y permiten que solo se expanda un panel; por lo que no admiten una función de colapso.
- Flecha abajo (opcional): Si el enfoque está en un encabezado de acordeón, mueve el enfoque al siguiente encabezado de acordeón. Si el foco está en el último encabezado del acordeón, o no hace nada o mueve el foco al primer encabezado del acordeón.
- Flecha hacia arriba (opcional): Si el enfoque está en un encabezado de acordeón, mueve el enfoque al encabezado de acordeón anterior. Si el foco está en el primer encabezado del acordeón, o no hace nada o mueve el foco al último encabezado del acordeón.
- Inicio (Opcional): Cuando el enfoque está en un encabezado de acordeón, mueve el enfoque al primer encabezado de acordeón.
- Fin (Opcional): Cuando el enfoque está en un encabezado de acordeón, mueve el enfoque al último encabezado de acordeón.
- Ctrl+Page Down (Opcional): Si el enfoque está dentro de un panel de acordeón o en un encabezado de acordeón, mueve el enfoque al siguiente encabezado de acordeón. Si el enfoque está en el último encabezado o panel de acordeón, o no hace nada o mueve el foco al primer encabezado de acordeón.
- Ctrl+Page Up (Opcional): Si el foco está dentro de un panel de acordeón, mueve el foco al encabezado de ese panel. Si el enfoque está en un encabezado de acordeón, mueve el enfoque al encabezado de acordeón anterior. Si el foco está en el primer encabezado del acordeón, o no hace nada o mueve el foco al último encabezado del acordeón.
Fuente: Patrones de diseño de acordeón WAI-ARIA
Se ha creado la siguiente función OnKeyDown
para agregar operabilidad del teclado a los elementos de encabezado del acordeón, permitiendo que tanto la barra espaciadora como las teclas Enter operen los alternadores (es decir, encabezados) que abren y cierran los paneles, y las teclas de flecha para moverse entre los encabezados del acordeón. Por defecto, los usuarios pueden navegar entre encabezados, y entre encabezados y paneles usando la tecla Tab.
Acordeón accesible en acción
Mira el siguiente video para ver cómo ChromeVox interactúa con un acordeón. La tecla Tab se utiliza para navegar en los acordeones, moverse entre encabezados de acordeón y moverse entre encabezados y paneles de acordeón. Las teclas de flecha también se pueden usar para moverse entre encabezados de acordeón, pero no de encabezados a un panel asociado. Apunta a que el acordeón que actualices en la actividad en la siguiente página opere y anuncie como el del video.
Video: Acordeones Accesibles