Accessibility in HTML
Ensuring accessibility is essential for making web content usable by people with disabilities. HTML provides several features and best practices to improve accessibility and ensure inclusivity for all users.
Semantic Elements
Using semantic HTML elements properly helps screen readers and other assistive technologies understand the structure and context of the content.
<header>
<header>
<h1>Welcome to My Website</h1>
<nav>
<ul>
<li><a href="/">Home</a></li>
<li><a href="/about">About</a></li>
<li><a href="/contact">Contact</a></li>
</ul>
</nav>
</header>
<main>
<main>
<article>
<h2>Article Title</h2>
<p>Article content goes here...</p>
</article>
</main>
<nav>
<nav>
<ul>
<li><a href="/">Home</a></li>
<li><a href="/products">Products</a></li>
<li><a href="/services">Services</a></li>
</ul>
</nav>
ARIA Roles and Attributes
The Accessible Rich Internet Applications (ARIA) specification provides additional attributes to enhance the accessibility of HTML elements.
role
Attribute
<div role="navigation">
<ul>
<li><a href="/">Home</a></li>
<li><a href="/products">Products</a></li>
<li><a href="/services">Services</a></li>
</ul>
</div>
aria-label
Attribute
<button aria-label="Close">X</button>
Form Accessibility
Forms should be accessible to users with disabilities, providing clear labels and error messages.
Labeling Inputs
<label for="username">Username:</label>
<input type="text" id="username" name="username" />
Error Messages
<input type="email" id="email" name="email" required aria-describedby="email-error">
<span id="email-error" role="alert">Please enter a valid email address</span>
Keyboard Accessibility
Ensure all interactive elements can be accessed and operated using the keyboard alone.
Focus Styles
:focus {
outline: 2px solid blue;
}
Tabindex Attribute
<div tabindex="0">Focusable Div</div>
Testing and Validation
Regularly test your website with screen readers and other assistive technologies to ensure it's accessible to all users.