Simple Accessible Accordion React Component

Blog

Posted by Nuno Marques on 3 Nov 2020

In the world of web development, accessibility is a crucial aspect often overlooked by many developers. It's not just about creating visually appealing websites or applications; it's also about ensuring that everyone, regardless of their abilities or disabilities, can access and use digital content effectively. One common UI component that requires special attention to accessibility is the accordion.

An accordion is a user interface pattern that allows users to toggle the visibility of content sections. When implemented properly, accordions can significantly enhance the user experience, especially for navigating through large amounts of content. However, without proper accessibility features, accordions can pose challenges for users who rely on screen readers or keyboard navigation.

Today, we'll delve into a React component that implements an accessible accordion and explore why accessibility is so important in modern web development.

The Code: Building an Accessible Accordion Component

Let's break down the code for a React accordion component and discuss its key features:

import React, { useState } from 'react'

export default function Accordion({ accordions }) {
  const [activeAccordion, setActiveAccordion] = useState(null)

  const handleAccordionClick = (accordionIndex) => {
    setActiveAccordion(
      accordionIndex === activeAccordion ? null : accordionIndex
    )
  }

  return (
    <div className="accordion" role="tablist">
      {accordions.map((accordion, index) => (
        <div key={index}>
          <button
            onClick={() => handleAccordionClick(index)}
            aria-expanded={activeAccordion === index}
            aria-controls={`accordion-${index}`}
            tabIndex={0} // Ensure keyboard focusability
          >
            {activeAccordion === index ? 'Hide' : 'Show'} {accordion.title}
          </button>
          <div
            id={`accordion-${index}`}
            role="tabpanel"
            aria-labelledby={`accordion-${index}`}
            aria-hidden={activeAccordion !== index}
            ref={(contentRef) => {
              // Ref for focus management
              if (activeAccordion === index) {
                contentRef.current.focus()
              }
            }}
          >
            {accordion.content}
          </div>
        </div>
      ))}
    </div>
  )
}

Key Features:

  • State Management: The component uses React's useState hook to manage the state of the active accordion item.

  • Event Handling: handleAccordionClick function toggles the active accordion item when a button is clicked.

  • Accessibility Attributes:

    • aria-expanded indicates whether the accordion item is expanded or collapsed.
    • aria-controls associates the button with the corresponding content area.
    • role="region" and aria-labelledby provide semantic meaning and labeling for screen readers.
    • aria-hidden ensures that inactive accordion items are hidden from screen readers.

Importance of Accessibility in Accordions

Accordions are commonly used to organize and present content in a compact and manageable way. However, they can present barriers to users with disabilities if not implemented accessibly. Here's why accessibility matters for accordions:

  • Screen Reader Compatibility: Proper use of ARIA (Accessible Rich Internet Applications) attributes ensures that screen readers can interpret and announce accordion elements correctly, providing a smooth navigation experience for users with visual impairments.
  • Keyboard Navigation: Accessible accordions allow users to navigate through accordion items using keyboard controls alone, without relying on a mouse. This is particularly important for users with mobility impairments who may have difficulty using a mouse.
  • Focus Management: Ensuring that keyboard focus is appropriately managed when toggling accordion items helps users maintain context and orientation within the page, improving overall usability.
  • Compliance with Accessibility Standards: By adhering to accessibility guidelines such as WCAG (Web Content Accessibility Guidelines), developers can ensure that their applications are inclusive and compliant with legal requirements.

Conclusion

Incorporating accessibility features into UI components like accordions is not just a best practice; it's a fundamental aspect of responsible web development. By making our digital products accessible to everyone, we create a more inclusive online environment where all users can participate equally. With the right techniques and tools, developers can build accessible accordions that enhance usability and ensure a positive user experience for all.