Bouw toegankelijke websites die iedereen kan gebruiken. Deze praktische gids helpt je WCAG 2.2 AA compliant code schrijven.
Waarom is dit belangrijk voor jou?
Goede code is meer dan werkende code. Als ontwikkelaar bepaal je of mensen je website kunnen gebruiken met hulptechnologieën.
Semantische HTML is de basis van echt kwalitatieve code. Gebruik je de juiste HTML-elementen en bouw je logische structuren? Dan begrijpen hulptechnologieën je code en kunnen mensen met een functiebeperking je componenten goed gebruiken. Tegelijk wordt je code overzichtelijker voor andere ontwikkelaars én makkelijker te onderhouden.
Schrijf direct toegankelijke code. Bestaande componenten refactoren kost veel meer tijd en geld.
Je belangrijkste taken
1. Gebruik betekenisvolle HTML
Gebruik HTML-elementen waar ze voor bedoeld zijn. Browsers en hulptechnologieën snappen dan automatisch wat elk element doet.
De regels:
- Koppen:
<h1>,<h2>,<h3>voor koppen en subkoppen - Lijsten:
<ul>,<ol>,<dl>voor opsommingen - Tabellen:
<table>,<th>,<td>voor tabellen - Links:
<a>voor verwijzingen naar een andere locatie - Knoppen:
<button>voor acties (zoals “Opslaan” of “Menu openen”) - Landmarks:
<main>,<nav>,<aside>voor de structuur van de pagina
Voorbeeld:
<main>
<h1>Productpagina</h1>
<h2>Kenmerken</h2>
<ul>
<li>Lichtgewicht</li>
<li>Waterdicht</li>
</ul>
<h2>Technische gegevens</h2>
<table>
<tr>
<th>Gewicht</th>
<td>1.2 kg</td>
</tr>
<tr>
<th>Hoogte</th>
<td>30 cm</td>
</tr>
</table>
<aside>
<a href="/downloads">Handleiding (PDF)</a>
</aside>
<button>Bestel nu</button>
</main>
Tip: Begin altijd met werkende HTML. Voeg pas daarna CSS en JavaScript toe.
2. Maak alle functionaliteit bereikbaar met het toetsenbord
Zorg dat mensen ook alle bedieningselementen kunnen bereiken zonder een muis of touchpad.
De regels:
- Alle links, knoppen en formulierelementen zijn bereikbaar met de Tab-toets
- Focus volgorde is logisch
- Focusindicator is duidelijk zichtbaar
<!-- Slecht voorbeeld -->
<div onclick="openMenu()">Menu</div>
<!-- Goed voorbeeld -->
<button type="button" onclick="openMenu()" onkeydown="handleKeydown(event)">Menu</button>
De 5-minuten check
- Stop je muis weg (of koppel hem los)
- Navigeer alleen met toetsenbord:
- Tab = volgende element
- Shift + Tab = vorige element
- Controleer deze punten:
- Kom je overal?
- Zie je waar je bent? (Is de focusindicator zichtbaar?)
- Werken alle knoppen en links?
- Kun je menu’s openen en sluiten?
- Raak je ergens ‘vast’?
3. Voeg een skiplink toe
Help gebruikers om herhaalde navigatie over te slaan door een skiplink te gebruiken.
Voorbeeld:
<body>
<a href="#main" class="skiplink">Ga naar hoofdinhoud</a>
<nav>...</nav>
<main id="main">...</main>
</body>
.skiplink {
position: absolute;
left: -10000px;
width: 1px;
height: 1px;
overflow: hidden;
}
.skiplink:focus {
position: static;
left: auto;
width: auto;
height: auto;
overflow: visible;
padding: 8px;
background: #000;
color: #fff;
}
De 5-minuten check
- Herlaad je pagina
- Druk op de Tab-toets:
- Is het eerste element een skiplink?
- Wordt de skiplink zichtbaar?
4. Formulieren toegankelijk maken
Maak formulieren die iedereen kan begrijpen en gebruiken.
Verplichte elementen:
- Alle
<input>-elementen hebben een gekoppeld<label> - Verplichte velden zijn visueel én in de code gemarkeerd
- Velden met een verkeerde invoer zijn in de code gemarkeerd met
aria-invalid="true" - Foutmeldingen zijn gekoppeld met het
aria-describedby-attribuut - Gegroepeerde formulierelementen gebruiken het
<fieldset>-element met<legend>
Voorbeeld:
<form>
<label for="email">
E-mailadres *
</label>
<input type="email" id="email" required aria-invalid="true" aria-describedby="email-error">
<div id="email-error">
Het e-mailadres is niet geldig. Gebruik het formaat niek@wcag.nl.
</div>
</form>
Hulpmiddelen voor ontwikkelaars
Toegankelijkheid checken:
- axe DevTools (browser extensie)
- Toont direct alle automatisch gevonden problemen
- Download axe DevTools:
- WAVE Web Accessibility Evaluator (website)
- Plak je URL in het veld
- Toont direct alle automatisch gevonden problemen
- Web Developer (browser extensie)
- Geeft informatie over je pagina
Koppenstructuur bekijken:
- headingsMap (browser extensie)
- Toont een overzicht van al je koppen en landmarks
- Laat sprongen in niveaus zien
- Download headingsMap:
Valideer je code:
- W3C Markup Validator (website)
- Controleert je HTML structuur
Lees meer over hulpmiddelen bij het toetsen
Praktische tips
Afbeeldingen
- Zorg dat alle
<img>-elementen eenalt-attribuut hebben. Gebruik legealt-attributen (alt="") alleen voor puur decoratieve afbeeldingen. - Geef informatieve en functionele
<svg>-elementen eenrole="img"en eentitle-element als eerste content. - Zorg dat de toegankelijke naam van knoppen en links met afbeeldingen overeenkomt met de zichtbare tekst.
Bediening
- Maak alle interactieve elementen (links, knoppen, formulieren) bereikbaar en bedienbaar met het toetsenbord.
- Voeg een skiplink toe.
- Zorg voor een logische focus volgorde.
- Zorg dat de focusindicator overal zichtbaar is en niet volledig wordt bedekt door andere elementen.
Formulieren
- Koppel elk invoerveld aan een label (met het
for-attribuut of door het invoerveld in het<label>-element te plaatsen). - Gebruik het
autocomplete-attribuut voor veelvoorkomende invoervelden die persoonlijke gegevens van de gebruiker verzamelen, zoals naam, e-mail en adres. - Koppel foutmeldingen aan het juiste invoerveld met
aria-describedby.
Navigeren
- Gebruik het
<title>-element in de<head>-sectie van de pagina. - Zorg voor een zoekfunctie of een sitemap op je website.
Techniek
- Zorg dat de volgorde in de code overeenkomt met de visuele volgorde.
- Zorg dat de toegankelijke naam van bedieningselementen de zichtbare tekst bevat.
- Gebruik
lang-attribuut op het<html>-element voor de hoofdtaal van de pagina. - Geef alle bedieningselementen een toegankelijke naam, rol en waarde. Gebruik ARIA alleen als HTML-elementen niet volstaan.
Tekst
- Zorg dat de koppen (
<h1>tot<h6>) logisch en in de juiste volgorde worden gebruikt. - Gebruik
<ol>voor geordende lijsten en<ul>voor ongeordende lijsten. - Gebruik
<table>,<th>en<td>op de juiste manier. Gebruik bij complexere tabellen ookscope="col"en/ofscope="row.
Weergave
- Zorg dat de website zowel in staande (portrait) als liggende (landscape) weergave goed werkt.
- Zorg dat de hele content leesbaar en bedienbaar blijft bij 400% zoom.
- Voorkom dat iemand moet scrollen in twee richtingen (horizontaal én verticaal) na het inzoomen.
Handige bronnen
Succescriteria
Alle succescriteria waar ontwikkelaars bij betrokken zijn:
Afbeeldingen
Bediening
- 1.4.2 Geluidsbediening
- 1.4.13 Content bij hover of focus
- 2.1.1 Toetsenbord
- 2.1.2 Geen toetsenbordval
- 2.1.4 Enkel teken sneltoetsen
- 2.2.2 Pauzeren, stoppen, verbergen
- 2.4.1 Blokken omzeilen
- 2.4.3 Focus volgorde
- 2.4.7 Focus zichtbaar
- 2.4.11 Focus niet bedekt (minimum)
- 2.5.1 Aanwijzergebaren
- 2.5.2 Aanwijzerannulering
- 2.5.4 Bewegingsactivering
- 2.5.7 Sleepbewegingen
- 2.5.8 Grootte van het aanwijsgebied (minimum)
- 3.2.1 Bij focus
Beweging
Formulieren
- 1.3.1 Info en relaties
- 1.3.5 Identificeer het doel van de input
- 2.2.1 Timing aanpasbaar
- 2.4.6 Koppen en labels
- 3.2.2 Bij input
- 3.3.1 Foutidentificatie
- 3.3.2 Labels of instructies
- 3.3.3 Foutsuggestie
- 3.3.4 Foutpreventie (wettelijk, financieel, gegevens)
- 3.3.7 Overbodige invoer
- 3.3.8 Toegankelijke authenticatie (minimum)
- 4.1.3 Statusberichten
Media
Navigeren
Ontwerp
Techniek
- 1.3.2 Betekenisvolle volgorde
- 1.3.4 Weergavestand
- 2.2.1 Timing aanpasbaar
- 2.5.3 Label in naam
- 3.2.1 Bij focus
- 3.2.2 Bij input
- 4.1.1 Parsen
- 4.1.2 Naam, rol, waarde
- 4.1.3 Statusberichten
Tekst
- 1.3.1 Info en relaties
- 2.4.2 Paginatitel
- 2.4.4 Linkdoel (in context)
- 2.4.6 Koppen en labels
- 3.1.1 Taal van de pagina
- 3.2.4 Consistente identificatie
Weergave
Meer hulp nodig?
Heb je vragen over toegankelijkheid, behoefte aan advies of wil je een onderzoek laten uitvoeren? Stuur me dan gerust een bericht via niek@wcag.nl of bezoek WCAG.nl voor meer informatie.
Ik maak WCAG-richtlijnen begrijpelijk en help je met het vinden van praktische oplossingen.