Toegankelijke links

Een duidelijke linktekst helpt bezoekers te begrijpen waar ze naartoe gaan als ze klikken. Dit is extra belangrijk voor mensen die een schermlezer gebruiken.

Linkteksten vallen onder succescriterium 2.4.4 Linkdoel (in context) van de richtlijnen voor toegankelijkheid van webcontent.

Links gebruiken

Zorg dat de linktekst het doel van de link beschrijft. Vraag jezelf af: welke informatie of welke pagina staat er achter deze link? Gebruik geen algemene linkteksten zoals “Lees meer” of “Klik hier”. Schrijf in plaats daarvan bijvoorbeeld “Lees meer over toegankelijke links”.

Gebruik links alleen om te verwijzen naar een andere locatie. Bijvoorbeeld naar een andere website, een andere pagina op jouw website of een andere plek op de dezelfde pagina.

In een CMS kun je meestal eenvoudig een link toevoegen via de editor. Selecteer de tekst die een link moet worden en voeg de link toe. (Vaak ziet dit icoon er uit als schakels in een ketting.)

In WordPress ziet dit er zo uit:

Tekst met daarboven de block-editor van WordPress. In deze balk kan het worden gekozen om van de tekst een link te maken. In het invoerveld wordt de URL ingevuld.

Code voor links

Links worden in de code opgemaakt met het <a>-element. Dit element heeft het href-attribuut, waarin je de verwijzing toegevoegd. Alle content die tussen de begintag en de eindtag van het <a>-element staat vormt de linktekst.

<a href="https://www.niekderksen.nl/artikelen">Artikelen</a>

Functionele afbeeldingen

Je kunt ook een afbeelding als link gebruiken. In dat geval wordt het tekstalternatief van de afbeelding de linktekst. Dit tekstalternatief geef je aan met het alt-attribuut van het <img>-element.

<a href="https://wcag.nl">
  <img src="logo-wcag.jpg" alt="WCAG.nl">
</a>

Lees meer over tekstalternatieven bij een afbeelding

Context van de link

Soms past een uitgebreide linktekst niet goed in het ontwerp van de pagina. In dat geval mag je ook de omringende context gebruiken om duidelijk te maken waar de link naartoe gaat. Doorgaans is dit de content uit hetzelfde HTML-element.

De omliggende context is bijvoorbeeld:

  • tekst in dezelfde zin of alinea
  • tekst in dezelfde tabelcel of in hetzelfde lijstonderdeel
  • het aria-label-attribuut
  • het aria-labelledby-attribuut
  • tekst verborgen met CSS
Tekst verbergen met CSS

Met CSS kan tekst buiten beeld worden geplaatst. Het is wel aanwezig in de leesvolgorde van een schermlezer, maar niet zichtbaar voor mensen die kunnen zien. Een schermlezer presenteert de tekst alsof het er gewoon staat.

In de HTML ziet dat er zo uit:

<a href="/tekstalternatieven"​>
  Lees meer <span class="sr-only"​>over tekstalternatieven</​span​>
</​a​>

Met de stijlkenmerken:

.sr-only {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

Tips voor toegankelijke links

Tot slot nog een paar tips voor het schrijven van een goede linktekst:

  • Gebruik geen teksten zoals “link:” of “link naar..” in de linktekst.
  • Zorg dat links die naar hetzelfde linkdoel verwijzen steeds dezelfde linktekst hebben.
  • Zorg dat links minimaal op 2 manieren te onderscheiden zijn van gewone tekst (bijvoorbeeld door een andere kleur én onderstreping).
  • Toon het volledige e-mailadres als de link naar een e-mailadres gaat.
  • Toon het volledige telefoonnummer als de link naar een telefoonnummer gaat.
  • Toon de extensie en grootte als de link naar een bestand gaat (bijvoorbeeld: “Jaarverslag 2024.pdf, 2,1 MB”).

Gerelateerde WCAG succescriterium

PDF’s toegankelijk maken

Informatie delen via een PDF is tegenwoordig (nog) heel gewoon. Maar wat als die PDF’s niet toegankelijk zijn voor iedereen? Bijvoorbeeld mensen die een schermlezer gebruiken, zoals voorleessoftware of een brailleleesregel. In dit artikel lees je hoe je PDF’s toegankelijk maakt voor iedereen.

Met Adobe Acrobat Pro DC kun je zelf toegankelijkheidsproblemen oplossen. Dit programma is beschikbaar voor Windows en Mac, maar is niet gratis te gebruiken.

In dit artikel:

  1. Eigenschappen instellen
  2. Tags

Eigenschappen instellen

In de instellingen van het PDF-bestand moeten een titel en de taal juist worden ingesteld.

Titel van het document

Stel de titel van het document in.

  1. Ga naar Bestand → Documenteigenschappen.
  2. In het dialoogvenster, ga naar de tab Beschrijving.
    • Gebruik het Titel-veld om de titel in te vullen.
  3. In het dialoogvenster, ga naar de tab Weergave bij openen.
    • In het onderdeel Vensteropties → Tonen, kies in de keuzelijst voor de optie Documenttitel.
Taal van het document

Stel de taal van het document in.

  1. Ga naar Bestand → Documenteigenschappen.
  2. In het dialoogvenster, ga naar de tab Geavanceerd.
    • In het onderdeel Leesopties → Taal, kies in de keuzelijst de juiste taal.

Tags

Tags vormen een codelaag die wordt toegevoegd aan een PDF-bestand betekenis te geven aan de elementen van de PDF. Deze semantiek helpt schermlezers, zoals voorleessoftware of een brailleleesregel, om de inhoud van een PDF kunnen te interpreteren en presenteren.

Er zijn verschillende soorten tags:

  1. Container-tags: Tags die worden gebruikt om meerdere tags te groeperen.
  2. Block-tags: Tags die worden gebruikt om grotere blokken content, zoals paragrafen, koppen en lijsten, te structureren.
  3. Inline-tags: Tags die worden gebruikt om onderdelen binnen een block-tag te markeren, zoals een link of citaat.
  4. Tags voor grafische objecten: Tags die worden gebruikt voor afbeeldingen, diagrammen en andere informatieve visuele elementen.

Tags voor container-elementen

Gebruik de volgende tags voor containers:

  • <Document>: Document
  • <Part>: Onderdeel in een document
  • <Art>: Artikel
  • <Sect>: Sectie
  • <Div>: Delen die geen semantische betekenis hebben maar wel samen een geheel vormen
  • <Caption>: Eén of meerdere tags die een onderdeel beschrijven
Inhoudsopgave

Gebruik de volgende tags voor een inhoudsopgave:

  • <TOC>: Inhoudsopgave
  • <TOCI>: Onderdelen in een inhoudsopgave
  • <P>: Tekst
  • <Reference>: Verwijzingen
  • <Link> en <Link-OBJR>: Links
  • <Caption>: Beschrijving (optioneel)
<TOC>
  <TOCI>
    <P>
      <Reference>
        <Link>
          Hoofdstuk 1
          <Link-OBJR>
  <TOC>
    <TOCI>
      <P>
        <Reference>
          <Link>
            Hoofdstuk 1.1
            <Link-OBJR>
Citaat die uit meerdere tags bestaat

Gebruik de <BlockQuote>-tag voor citaten die bestaan uit meerdere tags.

<BlockQuote>
  <P>
    Tekst
  <P>
    Tekst

Tags voor block-elementen

Paragrafen

Gebruik de <P>-tag voor tekst.

<P>
  Tekst

Afwijkende taal

Stel de taal in van een tekst dat in een andere taal is geschreven.

  1. Open de Eigenschappen van de tag in een andere taal.
  2. In het dialoogvenster, ga naar de tab Code.
    • In het onderdeel Taal, kies in de keuzelijst de juiste taal.
Koppen

Gebruik <H1>– tot en met <H6>-tags voor koppen.

<H1>
  Koptekst
Lijsten

Gebruik de volgende tags voor een lijst:

  • <L>: Lijst
  • <LI>: Onderdelen in een lijst
  • <Lbl>: Opsommingstekens
  • <LBody>: Tekst in een onderdeel van een lijst
  • <Caption>: Beschrijving (optioneel)
<L>
  <LI>
    <Lbl>
      1.
    <LBody>
      Lijstonderdeel
  <L>
    <LI>
      <Lbl>
        1.1
      <LBody>
        Onderliggend lijstonderdeel
Tabellen

Gebruik de volgende tags voor een tabel:

  • <Table>: Tabel
  • <TR>: Tabelrijen
  • <TH>: Tabelkoppen
  • <TD>: Gegevenscellen
  • <Caption>: Beschrijving (optioneel)
<Table>
  <TR>
    <TH>
      Tabelkop van kolom 1
    <TH>
      Tabelkop van kolom 2
  <TR>
    <TD>
      Gegevenscel 1
    <TD>
      Gegevenscel 2

Tabelkoppen koppelen

Stel het bereik van een tabelkop in. Voor een eenvoudige tabel is een impliciete koppeling tussen tabelkop en gegevenscel genoeg.

  1. Open de Tabeleditor.
  2. Klik met de rechtermuisknop op elke tabelkop en selecteer Eigenschappen van tabelcel.
    • In het onderdeel Type, kies het keuzerondje Kopcel.
    • In het onderdeel TypeBereik, kies in de keuzelijst het juiste bereik.

Voor een complexe tabel is een expliciete koppeling tussen tabelkop en gegevenscel nodig.

  1. Open de Tabeleditor.
  2. Klik met de rechtermuisknop op elke tabelkop en selecteer Eigenschappen van tabelcel.
    • In het onderdeel Kenmerken, gebruik het id-veld om een unieke waarde in te vullen.
  3. Klik met de rechtermuisknop op elke gegevenscel en selecteer Eigenschappen van tabelcel.
    • In het onderdeel Kenmerken, voeg met de +-knop in het onderdeel Gekoppelde kopcel-id’s een koppeling toe met de id’s van de bijbehorende tabelkoppen.
Voetnoten

Gebruik de volgende tags voor voetnoten:

  • <Reference>: Verwijzingen
  • <Note>: Voetnoot
<P>
  <Reference>
    <Lbl>
      1. 
  <Note>
    <Lbl>
      1.
    <P>
      Tekst

Tags voor inline-elementen

Links

Gebruik de volgende tags voor een link:

  • <Link>: Link
  • <Link-OBJR>: Link-OBJR annotatie
<Link>
  Linktekst
  <Link-OBJR>

Links toevoegen

  1. Open de Toegankelijkheidstags en selecteer Zoeken in de opties.
    • In het onderdeel Zoeken, kies in de keuzelijst voor de optie Niet-gemarkeerde koppelingen.
    • Kies voor Zoeken.
    • Als een tag is gevonden, kies voor Code-element
  2. In het onderdeel Type, kies in de keuzelijst voor de optie Link.
  3. Selecteer de linktekst.
  4. Open de Toegankelijkheidstags en selecteer Code maken van selectie in de opties.
  5. Open de Eigenschappen van de tag van een afbeelding.
    In het dialoogvenster, ga naar de tab Code.
    • Gebruik het Alternatieve beschrijving voor koppelingen-veld om het tekstalternatief in te vullen.
Citaten

Gebruik de <Quote>-tag voor een citaat in een paragraaf.

<P>
  Tekst
  <Quote>
    Citaat in een paragraaf
  Tekst

Tags voor grafische objecten

Informatieve of functionele afbeeldingen

Gebruik de volgende tags voor een afbeelding die informatie overdraagt of wordt gebruikt als link of knop:

  • <Figure>: Afbeelding
  • <Caption>: Beschrijving (optioneel)
<Figure>

Tekstalternatief toevoegen

  1. Open de Eigenschappen van de tag van een informatieve of functionele afbeelding.
  2. In het dialoogvenster, ga naar de tab Code.
    • Gebruik het Alternatieve tekst voor afbeeldingen-veld om het tekstalternatief in te vullen.

Bronnen

YouTube-filmpjes toegankelijk insluiten

Eerder schreef ik een artikel over toegankelijke filmpjes en geluidsfragmenten. In dit artikel leg ik uit hoe je de YouTube-mediaspeler toegankelijker kunt instellen.

Insluitcode

Met een insluitcode (ook wel embed-code) kun je filmpjes van YouTube op een webpagina plaatsen. Deze code ziet er ongeveer zo uit:

<iframe width="560" height="315" src="https://www.youtube.com/embed/[VIDEO_ID]" title="YouTube video player" ... ></iframe>

In het src-attribuut van het <iframe>-element staat de URL van het filmpje. Je kunt parameters toevoegen aan deze URL om de toegankelijkheid van de mediaspeler te verbeteren. Deze parameters kun je in- of uitschakelen met de waarde 1 of 0.

  • autoplay: Hiermee bepaal je of een filmpje automatisch start. Standaard staat dit uit (autoplay=0). Het advies is om deze instelling uit te laten staan.
  • controls: Hiermee kun je de bedieningselementen van de mediaspeler tonen of verbergen. Standaard zijn deze zichtbaar (controls=1). Verberg de bedieningselementen nooit.
  • disablekb: Hiermee bepaal je of sneltoetsen kunnen worden gebruikt. Standaard staan sneltoetsen aan (disablekb=0). Het advies is om sneltoetsen uit te schakelen. Voeg disablekb=1 toe aan de URL.
  • fs: Hiermee bepaal je of een filmpje in volledig scherm kan worden afgespeeld. Standaard staat dit aan (fs=1). Het advies is om deze instelling aan te laten staan.

Lees meer over YouTube parameters

Na het aanpassen van de insluitcode ziet deze er zo uit:

<iframe width="560" height="315" src="https://www.youtube.com/embed/[VIDEO_ID]?disablekb=1" title="YouTube video player" ... ></iframe>

Toegankelijke naam

Geef het <iframe>-element een duidelijke toegankelijke naam. Schermlezers kunnen (onder andere) <iframe>-elementen presenteren in een handig overzicht. Hierdoor kunnen mensen die een schermlezer gebruiken sneller door de content navigeren.

Gebruik hiervoor het title-attribuut van het <iframe>-element. Standaard staat hier “YouTube video player”. Vervang dit door een beschrijving van wat er in het filmpje te zien is.

Na het aanpassen van de insluitcode ziet deze er (bijvoorbeeld) zo uit:

<iframe width="560" height="315" src="https://www.youtube.com/embed/[VIDEO_ID]?disablekb=1" title="Teckel en Border Collie spelend in een open weide" ... ></iframe>

Ondertitels

YouTube kan automatisch ondertitels genereren bij je filmpje. Deze ondertitels zijn vaak niet volledig correct. Ze kunnen wel veel werk besparen. Controleer daarom de gegenereerde ondertitels en verbeter ze waar nodig. Beschrijf in de ondertitels ook belangrijke geluiden die te horen zijn, zoals een deurbel, een explosie of belangrijke muziek.

YouTube gebruikt deze ondertitels ook om een transcript van het filmpje te maken.

Tips voor een toegankelijke mediaspeler

Tot slot nog een paar tips voor een toegankelijke mediaspeler:

  • Vermijd geluid dat automatisch speelt. Als je dit toch gebruikt, zorg dan dat gebruikers het eenvoudig kunnen pauzeren, stoppen of zachter kunnen zetten.
  • Gebruik geen sneltoetsen. Als je ze toch wil gebruiken, zorg dan dat gebruikers ze kunnen uitschakelen of aanpassen.
  • Vermijd automatisch bewegende content. Als je dit toch gebruikt, zorg dan dat gebruikers het eenvoudig kunnen pauzeren, stoppen of uitzetten.
  • Gebruik geen content dat meer dan 3 keer per seconde flitst.

Toegankelijke koppen

Koppen maken een tekst overzichtelijk. Ze zien er vaak wat anders uit dan gewone tekst: ze hebben grotere letters en zijn vetgedrukt. Dit is vooral handig voor mensen die dit kunnen zien. Maar structuur in de content moet ook door software te begrijpen zijn. Dan kan ook iemand die een schermlezer gebruikt een pagina snel scannen.

Koppen hebben verschillende functies:

  • Ze geven structuur aan de content.
  • Schermlezers kunnen een lijst maken van alle koppen op een webpagina. Zo kunnen bezoekers snel naar het juiste deel van de tekst gaan.
  • Schermlezers hebben een ingebouwde sneltoets waarmee snel van kop naar kop springen.
  • Zoekmachines gebruiken de koppen bij het beoordelen van de inhoud van een webpagina.

Correct gebruik van koppen is dus belangrijk voor toegankelijkheid, gebruiksvriendelijkheid en voor zoekmachines.

Het gebruik van koppen valt onder succescriterium 1.3.1 Info en relaties en succescriterium 2.4.6 Koppen en labels van de richtlijnen voor toegankelijkheid van webcontent.

Koppen gebruiken

In een CMS kun je via de editor meestal eenvoudig van gewone tekst een koptekst maken. Je selecteert de tekst en kiest welk kopniveau je wilt gebruiken. De editor maakt er dan HTML-code van met de juiste kop-elementen. Koppen worden opgemaakt met de HTML-elementen <h1> tot en met <h6>.

In WordPress ziet dit er zo uit:

Geselecteerde tekst met daarboven de block-editor van WordPress. In deze balk kan het kopniveau worden gekozen voor de geselecteerde tekst.

Let op: Gebruik koppen alleen om de content te structureren. Gebruik het kop-element niet om alleen een bepaalde presentatie van de tekst te bereiken. Tekst die géén kop is, mag niet worden opgemaakt met een HTML kop-element.

Gebruik een logische kopvolgorde

Zorg dat koppen worden gebruikt volgens in een logische kop-volgorde. Gebruik hiervoor een juiste hiërarchie: de <h1> is de belangrijkste kop op een pagina, een <h6> is het minst belangrijk.

Gebruik de <h1> voor de paginatitel aan het begin van de content. Dit helpt om het onderwerp van de pagina duidelijk te maken. Gebruik <h2>’s voor de belangrijkste koppen in de content en, als dat nodig is, de <h3>’s en misschien zelfs <h4>, <h5> of <h6> voor de tussenkoppen om de content verder in secties te verdelen. Sla geen kopniveau’s over.

Voorbeeld van een goede kopvolgorde:

<h1>Voorbeeld WCAG-onderzoek</h1>

  <h2>Inhoudsopgave</h2>

  <h2>Samenvatting</h2>

  <h2>Gegevens</h2>

    <h3>Website naam</h3>

    <h3>Scope</h3>

    <h3>Conformiteit</h3>

      <h4>Uitzonderingen</h4>

    <h3>Ondersteuning</h3>

    <h3>Vereisten</h3>

  <h2>Resultaten</h2>

    <h3>Principe 1: Waarneembaar</h3>

...

Schermlezers kunnen een lijst maken van alle koppen op een webpagina. Dit werkt net zoals de inhoudsopgave van een boek; De pagina wordt verdeeld in hoofdstukken, paragrafen en subparagrafen. Zo kunnen mensen die gebruik maken van een schermlezer snel en efficiënt navigeren in de content.

In de Rotor van VoiceOver ziet dit er zo uit:

Schermafbeelding van een VoiceOver Rotor met een overzicht van koppen van niveau 1, 2, 3, en 4.

Lees meer over voorleessoftware gebruiken

Beschrijf de onderliggende content

Zorg dat de koppen en de tussenkoppen een goed beeld geven van de content van een pagina. De tekst in de kop moet duidelijk en beschrijvend zijn voor de onderliggende content. Beschrijvende koppen zorgen dat het mogelijk is om een tekst goed te scannen en te voorspellen waar de relevante content staat. Zo krijgt de gebruiker een goed idee van wat hij kan verwachten.

Tips voor toegankelijke koppen

Tot slot nog een paar tips voor het gebruiken van koppen:

  • Gebruik maximaal één <h1> per pagina.
  • Zet de <h1> aan het begin van de content.
  • Zorg dat de koptekst van de <h1> (ongeveer) hetzelfde is als de titel van de pagina.
  • Houd kopteksten kort en duidelijk.

Zoek je een hulpmiddel om snel de koppen en kopvolgorde van een pagina te controleren? De browser extensie headingsMap geeft een overzicht van alle koppen en kopniveaus op een webpagina. Download op Windows of macOS voor Mozilla Firefox, Google Chrome of Microsoft Edge.

Gerelateerde WCAG succescriteria

Taal in de code vastleggen

Voorleessoftware kan tekst omzetten in spraak. Het gebruikt hier verschillende stemmen voor. Iedere stem is gemaakt om in een bepaalde taal te spreken. Om te bepalen in welke taal er moet worden gesproken is voorleessoftware afhankelijk van taal die in de code is vastgelegd.

Het vastleggen van de taal in de code heeft meerdere functies:

  • Voorleessoftware kan woorden en zinnen in de juiste taal uitspreken.
  • Browsers kunnen letters en karakters op de goede manier weergeven.
  • Zoekmachines gebruiken de taal van een webpagina om te bepalen of een pagina wordt opgenomen in zoekresultaten.

In dit artikel lees je hoe taal in de code kan worden vastgelegd.

Taal instellen

Meestal kan alleen een ontwikkelaar de hoofdtaal van de website instellen. Soms kan dit ook via de instellingen van het CMS.

Voor onderdelen van een webpagina kan je in een CMS de taal meestal makkelijk toevoegen in de editor op de pagina.

Code van taal instellen

Taal kan worden toegevoegd met het lang-attribuut. Gebruik als waarde van dit attribuut alleen een taalcode die voorkomt in de IANA Subtag Registry.

Een aantal veelgebruikte taalcodes:

TaalcodeTaal
nlNederlands
enEngels
frFrans
deDuits
plPools
itItaliaans
esSpaans
ptPortugees
Voorbeelden van taalcodes

Taal van de pagina

De standaard taal van een webpagina wordt aangegeven in het <html>-element. Voeg het lang-attribuut toe aan het <html>-element en gebruik de juiste taalcode.

<html lang="nl">

Taal van onderdelen

Woorden of zinnen of onderdelen van je website in een andere taal moet je apart markeren. Voeg hiervoor het lang-attribuut toe aan het HTML-element met een andere taal en gebruik de juiste taalcode.

Het lang-attribuut kan worden gebruikt op block-elementen (<div><p><ul>, enz.) maar ook op inline-elementen (<span><a><strong>, enz.).

Voorbeeld van een taalwissel met een block-element:

<p lang="en">The quick brown fox jumps over the lazy dog.</p>
<ul lang="fr">
  <li>Langue de la page</li>
  <li>Langue d’un passage</li>
</ul>

Voorbeeld van een taalwissel met een inline-element:

<p>In het Verenigd Koninkrijk zeggen ze <span lang="en">It’s raining cats and dogs.</span>.</p>

Gerelateerde WCAG succescriteria

Toegankelijke filmpjes en geluidsfragmenten

Met filmpjes en geluidsfragmenten kun je informatie op een snelle en eenvoudige manier overbrengen. Maar deze media zijn niet door iedereen goed te gebruiken, bijvoorbeeld als iemand niet (goed) kan horen of zien door een functiebeperking. Zorg daarom altijd voor een toegankelijk alternatief.

Ook voor mensen zonder functiebeperking is zo’n alternatief vaak gewenst. Zo kan een filmpje met ondertiteling ook goed worden gevolgd in de stiltecoupé van de trein.

In de richtlijnen voor toegankelijkheid van webcontent (de WCAG) wordt onderscheid gemaakt tussen verschillende vormen van media:

  • Geluidsfragmenten
  • Animaties (of andere bewegende beelden zonder geluid)
  • Filmpjes

Elementen van toegankelijke media

De elementen van toegankelijke geluidsfragmenten, animaties en filmpjes bestaan onder andere uit:

  • Tekstalternatief
  • Ondertitels
  • Audiodescriptie
  • Transcript
  • Gebarenvertolking

Tekstalternatief

Media valt onder de noemer ‘niet-tekstuele content’ en moet daarom, net zoals afbeeldingen, ook een tekstalternatief krijgen. Met een kort tekstalternatief kunnen mensen bepalen waar het stukje media over gaat en wat ze er mee willen doen. Ook als ze gebruik maken van een schermlezer of andere vorm van hulptechnologie.

Een kort tekstalternatief kan bijvoorbeeld worden toegevoegd met een goede koptekst boven het bestand of een korte beschrijving in de omringende tekst.

Ondertitels

Ondertitels zijn een tekstuele versie van de gesproken tekst in een filmpje dat gelijktijdig met het beeld wordt getoond. In ondertitels voor doven en slechthorenden worden óók alle belangrijke geluiden beschreven. Dat kunnen bijvoorbeeld geluidseffecten zijn, maar ook achtergrondgeluiden als ze belangrijk zijn om het filmpje goed te begrijpen.

Ondertitels maken filmpjes toegankelijker voor mensen met een auditieve beperking.

Ondertitels kunnen worden toegevoegd aan het beeld van een filmpje (open captions) of worden toegevoegd met een apart ondertitelbestand (closed captions).

Zorg dat ondertitels:

  • duidelijk zichtbaar zijn;
  • zo veel mogelijk gelijk lopen met het geluid;
  • geen andere informatie bedekken;
  • alle gesproken tekst bevatten;
  • alle belangrijke geluiden beschrijven;
  • alle namen van de spreker bevatten (als er meerdere mensen zijn die spreken);
  • het volume van de spreker benadrukken (als dit belangrijk is voor de context).

Audiodescriptie

Een audiodescriptie is een gesproken tekst, of een voice-over, die de belangrijke zichtbare informatie in een filmpje beschrijft als deze niet uit alleen het geluid te begrijpen is. Dat kan bijvoorbeeld gaan over tekst die in het filmpje te zien is, maar ook over veranderingen in omgeving of personage of over handelingen die worden uitgevoerd.

Een audiodescriptie maakt filmpjes toegankelijker voor mensen met een visuele beperking.

Een audiodescriptie kan worden toegevoegd in het geluid van het filmpje of eventueel als tweede geluidsspoor. Een tweede geluidsspoor wordt helaas nog niet (goed) ondersteund op de grote videoplatformen.

Zorg dat audiodescripties:

  • duidelijk verstaanbaar zijn;
  • zo veel mogelijk gelijk lopen met het beeld;
  • alle zichtbare tekst in beeld bevatten;
  • alle belangrijke beelden en gebeurtenissen beschrijven;
  • alle namen van de sprekers bevatten.

Transcript

Een transcript is een uitgeschreven versie van de gesproken tekst en de belangrijke geluiden in een filmpje of geluidsfragment. Het beschrijft wat er te zien en te horen is, wat er gezegd wordt en ook door wie.

Een transcript maakt geluidsfragmenten en animaties toegankelijker voor mensen met een visuele of auditieve beperking.

Dit kan bijvoorbeeld door een uitgebreide beschrijving toe te voegen in de buurt van het mediabestand.

Zorg dat transcripten:

  • in de buurt van het bijbehorende mediabestand worden getoond;
  • alle gesproken tekst bevatten;
  • alle belangrijke geluiden beschrijven;
  • alle zichtbare tekst in beeld bevatten;
  • alle belangrijke beelden en gebeurtenissen beschrijven;
  • alle links uit het filmpje bevatten;
  • alle namen van de sprekers bevatten.

Gebarenvertolking

Gebarenvertolking is een vertaling van gesproken tekst naar gebarentaal. Deze taal wordt uitgedrukt met bewegingen van de handen en armen en met gezichtsuitdrukkingen.

Door gebarenvertolking toe te voegen aan een filmpje worden filmpjes ook toegankelijk voor mensen met een auditieve beperking.

WCAG

Niet alle onderdelen zijn verplicht volgens de WCAG niveau AA. Niveau AA is de geldende verplichting vanuit de Nederlandse wetgeving. De onderdelen die wel verplicht zijn:

  1. Geef mediabestanden een kort tekstalternatief.
  2. Geef geluidsfragmenten een transcript.
  3. Geef animaties (of andere bewegende beelden zonder geluid) een transcript of audiodescriptie.
  4. Geef filmpjes ondertitels voor doven en slechthorenden.
  5. Geef filmpjes een audiodescriptie als niet alle zichtbare details uit het geluid te begrijpen zijn.

Uitzonderingen

Voor live uitgezonden filmpjes bestaat een uitzondering in de Nederlandse wetgeving. Als het filmpje ná de uitzending online blijft staan of ergens opnieuw wordt gepubliceerd dan moet deze wél toegankelijk worden gemaakt.

Ook media dat is gepubliceerd vóór 23 september 2020 valt onder de uitzonderingen. Ook hiervoor geldt; als het ergens opnieuw wordt gepubliceerd dan moet deze wél toegankelijk worden gemaakt.

Andere tips voor toegankelijke media

Tot slot nog een paar tips voor het maken van toegankelijke filmpjes en geluidsfragmenten:

  • Gebruik geen content dat meer dan 3 keer per seconde flitst.
  • Laat geluidsfragmenten, animaties of filmpjes die niet automatisch starten (of zorg voor een mechanisme om deze content te kunnen pauzeren, stoppen of zacht te zetten).
  • Zorg dat alle functionaliteit van de mediaspeler te bereiken en bedienen is met het toetsenbord.
  • Gebruik genoeg contrast voor bedieningselementen in de mediaspeler.
  • Gebruik genoeg contrast voor tekst.
  • Gebruik niet alleen kleur om informatie over te dragen.

Skiplinks

Op websites staan vaak blokken met content die op iedere pagina terug komen, zoals een logo, een zoekveld en een navigatie met een lijst van links. Mensen die alleen het toetsenbord gebruiken moeten eerst door deze blokken navigeren voordat ze bij de hoofdcontent van de webpagina komen, en dat op iedere pagina opnieuw.

Succescriterium 2.4.1 Blokken omzeilen vereist dat dit soort herhalende blokken met content overgeslagen kunnen worden. Dit kan redelijk eenvoudig met een zogenaamde skiplink. Een skiplink is een ankerlink aan het begin van een webpagina die direct verwijst naar de hoofdcontent. Een ontwikkelaar kan skiplinks toevoegen in de code van een website.

Een skiplink is bedoeld om het navigeren over een website prettiger te maken voor mensen die:

  • geen muis kunnen gebruiken door bijvoorbeeld een motorische beperking;
  • een schermlezer gebruiken, zoals voorleessoftware of een brailleleesregel;
  • de voorkeur hebben om alleen met het toetsenbord te navigeren.

Skiplinks worden in de code opgemaakt met een <a>-element. Het href-attribuut van dit element verwijst naar een id-attribuut van een element lager op de pagina, bijvoorbeeld het <main>-element.

<a href="#primary" class="skip">Naar de inhoud</a>
<main id="primary">

Skiplinks hoeven niet altijd zichtbaar te zijn. Verberg de skiplink bijvoorbeeld met CSS zodat het alleen voor hulptechnologieën te zien is. Dit kan met de volgende CSS:

.skip {
  position:absolute;
  left:-10000px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}

Maak de skiplink wel zichtbaar als het de toetsenbordfocus krijgt. Dit kan (bijvoorbeeld) met de volgende CSS:

.skip:focus {
  position: static;
  width: auto;
  height: auto;
}

Bij een ingewikkelde website kunnen meerdere skiplinks worden toegevoegd, zoals een skiplink naar de navigatie en naar de content. In de meeste gevallen is 1 skiplink genoeg.

Voorbeeldcode

In een stuk pagina-code ziet een skiplink er zo uit:

<body>
  <header>
    <a href="#primary" class="skip">Naar de inhoud</a>
    <a href="/"><img src="logo.jpg" alt="WCAG.nl"></a>
    <nav>
      <ul>
        <li><a href="/">Home</a></li>
        <li><a href="/artikelen">Artikelen</a></li>
        <li><a href="/onderzoek">Onderzoek</a></li>
        <li><a href="/over-ons">Over ons</a></li>
        <li><a href="/contact">Contact</a></li>
      </ul>
    </nav>
  </header>
  <main id="primary">
    ...
  </main>
</body>

Skiplinks kunnen ook in de content van een webpagina met veel tekst of links worden gebruikt. Gebruik hier een ankerlink aan het begin van de content die verwijst naar sectie in de content van de webpagina.

Een voorbeeld hiervan staat op de pagina “Voorbeeld WCAG-onderzoek“.

Gerelateerde WCAG succescriteria

Toegankelijke tabellen

Tabellen zijn een goede manier om complexe gegevens overzichtelijk weer te geven. Als ze goed zijn opgemaakt dan zijn tabellen door iedereen goed te gebruiken. Zorg daarom dat de tabellen gebruik maken van de juiste elementen in de code. Als de relaties tussen de gegevens ook in de code staan dan kan een schermlezer, zoals voorleessoftware of een brailleleesregel, de informatie uit de tabel op een logische manier presenteren.

In dit artikel staan handvatten voor het maken van een toegankelijke tabel.

Tabellen gebruiken

Een tabel kan in een CMS meestal makkelijk worden toegevoegd in de editor op de pagina. Geef aan welke cellen tabelkoppen zijn en in welke cellen gegevens staan.

Gebruik tabellen alleen als het de informatie duide­lijker maakt. Zorg voor simpele en overzichte­lijke tabellen.

Code voor tabellen

Tabellen worden in de code opgemaakt met het <table>-element. Dit element heeft onderliggende <tr>-, <th>-, en <td>-elementen:

  • Het <tr>-element wordt gebruikt voor een tabelrij.
  • Het <th>-element wordt gebruikt voor een tabelkop.
  • Gegevenscellen worden opgemaakt met <td>-elementen.

Het <caption>-element geeft de inhoud van de tabel in het kort weer. Het <caption>-element is optioneel.

Eenvoudige tabellen

In eenvoudige tabellen, zoals een tabel met 1 kolom of 1 rij met koppen, kan hulptechnologie de onderlinge relaties zelf bepalen. Gebruik de juiste HTML-elementen voor de tabelkoppen en de gegevenscellen.

Voorbeeld van een tabel met 1 kolom met koppen:

<table>
  <caption>Beschrijving van de tabelgegevens</caption>
  <tr>
    <th>Tabelkop van rij 1</th>
    <td>Gegevenscel 1</td>
    <td>Gegevenscel 2</td>
  </tr>
  <tr>
    <th>Tabelkop van rij 2</th>
    <td>Gegevenscel 3</td>
    <td>Gegevenscel 4</td>
  </tr>
</table>

Voorbeeld van een tabel met 1 rij met koppen:

<table>
  <caption>Beschrijving van de tabelgegevens</caption>
  <tr>
    <th>Tabelkop van kolom 1</th>
    <th>Tabelkop van kolom 2</th>
  </tr>
  <tr>
    <td>Gegevenscel 1</td>
    <td>Gegevenscel 2</td>
  </tr>
  <tr>
    <td>Gegevenscel 3</td>
    <td>Gegevenscel 4</td>
  </tr>
</table>

Complexe tabellen

Sommige tabellen zijn wat moeilijker. Bijvoorbeeld doordat er koppen in 2 richtingen staan. In deze tabellen moet in de code expliciet worden aangegeven welke kop bij welke cellen hoort. Dit kan met het scope-attribuut of het headers-attribuut.

scope-attribuut

Gebruik het scope-attribuut om aan te geven welke cellen bij de kop horen. Voeg het scope-attribuut toe aan de tabelkop van een rij of kolom. Het attribuut kan de waarde row of col hebben:

  • scope="col"⁣: Geeft aan dat de cel een kop is voor de kolom.
  • scope="row"⁣: Geeft aan dat de cel een kop is voor de rij.

Voorbeeld van een tabel met 1 kolom en 1 rij koppen met het scope-attribuut:

<table>
  <caption>Beschrijving van de tabelgegevens</caption>
  <tr>
    <td></td>
    <th scope="col">Tabelkop van kolom 1</th>
    <th scope="col">Tabelkop van kolom 2</th>
  </tr>
  <tr>
    <th scope="row">Tabelkop van rij 1</th>
    <td>Gegevenscel 1</td>
    <td>Gegevenscel 2</td>
  </tr>
  <tr>
    <th scope="row">Tabelkop van rij 2</th>
    <td>Gegevenscel 3</td>
    <td>Gegevenscel 4</td>
  </tr>
</table>

headers-attribuut

Gebruik het headers-attribuut om aan te geven welke kop bij de cel hoort. Dit kunnen meerdere koppen zijn. Het headers-attribuut koppelt de cel met het id-attribuut aan de cel.

Let op: Het headers-attribuut wordt niet breed ondersteund door schermlezers.

Voorbeeld van een tabel met 1 kolom en 1 rij koppen met het headers-attribuut:

<table>
  <caption>Beschrijving van de tabelgegevens</caption>
  <tr>
    <td></td>
    <th id="kolom1">Tabelkop van kolom 1</th>
    <th id="kolom2">Tabelkop van kolom 2</th>
  </tr>
  <tr>
    <th id="rij1">Tabelkop van rij 1</th>
    <td headers="rij1 kolom1">Gegevenscel 1</td>
    <td headers="rij2 kolom1">Gegevenscel 2</td>
  </tr>
  <tr>
    <th id="rij2">Tabelkop van rij 2</th>
    <td headers="rij2 kolom1">Gegevenscel 3</td>
    <td headers="rij2 kolom2">Gegevenscel 4</td>
  </tr>
</table>

Nog complexere tabellen

Het is mogelijk om complexere tabellen te gebruiken. Bijvoorbeeld met koppen voor meerdere rijen en kolommen. Pas hier wel wel op; met te veel informatie in een tabel kan het onoverzichtelijk worden. Kies dan liever voor 2 of meerdere eenvoudige tabellen.

<thead>-, <tbody>- en <tfoot>-elementen

Voor het opbouwen van een tabel met meerdere rijen met koppen kunnen <thead>-, <tbody>-, en <tfoot>-elementen worden gebruikt.

  • Het <thead>-element wordt gebruikt voor de rijen met koppen.
  • Het <tbody>-element wordt gebruikt voor de rijen met gegevenscellen.
  • Gebruik het <tfoot>-element voor het resultaat van de bovenliggende gegevenscellen.

De <thead>-, <tbody>-, en <tfoot>-elementen kunnen ook goed gebruikt worden om stijlkenmerken toe te voegen aan onderdelen van de tabel.

<table>
  <caption>Beschrijving van de tabelgegevens</caption>
  <thead>
    <tr>
      <td rowspan="2"></td>
      <th colspan="2">Tabelkop van kolom 1 en 2</th>
      <th colspan="2">Tabelkop van kolom 3 en 4</th>
    </tr>
    <tr>
      <th scope="col">Tabelkop van kolom 1</th>
      <th scope="col">Tabelkop van kolom 2</th>
      <th scope="col">Tabelkop van kolom 3</th>
      <th scope="col">Tabelkop van kolom 4</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <th scope="row">Tabelkop van rij 1</th>
      <td>Gegevenscel 1</td>
      <td>Gegevenscel 2</td>
      <td>Gegevenscel 3</td>
      <td>Gegevenscel 4</td>
    </tr>
    <tr>
      <th scope="row">Tabelkop van rij 2</th>
      <td>Gegevenscel 5</td>
      <td>Gegevenscel 6</td>
      <td>Gegevenscel 7</td>
      <td>Gegevenscel 8</td>
    </tr>
  </tbody>
  <tfoot>
    <th scope="row">Tabelkop van rij 3</th>
    <td>Som gegevens 1 en 5</td>
    <td>Som gegevens 2 en 6</td>
    <td>Som gegevens 3 en 7</td>
    <td>Som gegevens 4 en 8</td>
  </tfoot>
</table>

De <thead>-, <tbody>-, en <tfoot>-elementen kunnen ook worden gebruikt in eenvoudige tabellen.

colgroup-attribuut en rowgroup-attribuut

Als een kop geldt voor meerdere kolommen of rijen, gebruik dan de waarden:

  • scope="colgroup"⁣: Geeft aan dat de cel een kop is voor meerdere kolommen.
  • scope="rowgroup"⁣: Geeft aan dat de cel een kop is voor meerdere rijen.

Om deze opzet goed te gebruiken moet eerst de kolomstructuur worden vastgelegd. Deze wordt aan het begin van de tabel gedefinieerd met het <colgroup>-element. Hierin wordt een kolom gedefinieert met het <col>-element. Zorg dat de som van het totaal aantal vastgelegde kolommen gelijk is aan het aantal kolommen in de tabel.

Het <col>-element kan ook goed gebruikt worden om stijlkenmerken toe te voegen aan een kolom.

<table>
  <caption>Beschrijving van de tabelgegevens</caption>
  <colgroup>
    <col span="2">
    <col span="2" style="background-color:tomato;">
    <col span="2">
  </colgroup>
  <tr>
    <td rowspan="2" colspan="2"></td>
    <th colspan="2" scope="colgroup">Tabelkop van kolom 1 en 2</th>
    <th colspan="2" scope="colgroup">Tabelkop van kolom 3 en 4</th>
  </tr>
  <tr>
    <th scope="col">Tabelkop van kolom 1</th>
    <th scope="col">Tabelkop van kolom 2</th>
    <th scope="col">Tabelkop van kolom 3</th>
    <th scope="col">Tabelkop van kolom 4</th>
  </tr>
  <tr>
    <th rowspan="2" scope="rowgroup">Tabelkop van rij 1 en 2</th>
    <th scope="row">Tabelkop van rij 1</th>
    <td>Gegevenscel 1</td>
    <td>Gegevenscel 2</td>
    <td>Gegevenscel 3</td>
    <td>Gegevenscel 4</td>
  </tr>
  <tr>
    <th scope="row">Tabelkop van rij 2</th>
    <td>Gegevenscel 5</td>
    <td>Gegevenscel 6</td>
    <td>Gegevenscel 7</td>
    <td>Gegevenscel 8</td>
  </tr>
</table>

Deze tabel ziet er zo uit:

Beschrijving van de tabelgegevens
Tabelkop van kolom 1 en 2 Tabelkop van kolom 3 en 4
Tabelkop van kolom 1 Tabelkop van kolom 2 Tabelkop van kolom 3 Tabelkop van kolom 4
Tabelkop van rij 1 en 2 Tabelkop van rij 1 Gegevenscel 1 Gegevenscel 2 Gegevenscel 3 Gegevenscel 4
Tabelkop van rij 2 Gegevenscel 5 Gegevenscel 6 Gegevenscel 7 Gegevenscel 8

Grote tabellen

Voeg een horizontale scroll toe als een webpagina niet breed genoeg is om de inhoud van een tabel volledig weer te geven. Deze wordt toegevoegd in de code. Voeg hiervoor overflow-x:auto toe aan de stijlkenmerken van de container rondom de tabel.

Zorg dan ook dat de horizontale scroll van de tabel met het toetsenbord te bereiken en bedienen is. Dit wordt gedaan met het tabindex-attribuut.

<div style="overflow-x:auto;" tabindex="0">
  <table>
    ...
  </table>
</div>

Gerelateerde WCAG succescriteria

Tekstalternatief bij een afbeelding

Succescriterium 1.1.1 Niet-tekstuele content lijkt erg eenvoudig: Geef alle niet-tekstuele content op een pagina een passend alternatief dat wel uit tekst bestaat. Toch gaat dit in de praktijk vaak mis.

In dit artikel staan handvatten voor het toevoegen van een tekstalternatief aan een afbeelding zoals een foto, illustratie of icoon. Hier kan een contentspecialist, webredacteur of ontwikkelaar afbeeldingen direct toegankelijker mee maken.

Succescriterium 1.1.1 Niet-tekstuele content valt onder principe 1: Waarneembaar van de richtlijnen voor toegankelijkheid van webcontent. Dit principe moet zorgen dat iedereen een website, document of app kan ervaren met de zintuigen die voor hen beschikbaar zijn. Niet iedereen heeft namelijk altijd, alle zintuigen ter beschikking.

Tekstalternatieven hebben meerdere functies:

  • Schermlezers gebruiken het tekstalternatief om niet-tekstuele content te presenteren. Zo kan voorleessoftware tekst omzetten in spraak en kan een brailleleesregel tekst vertalen naar braille. Op deze manier wordt niet-tekstuele content ook toegankelijk voor mensen met een visuele beperking.
  • Browsers laten het tekstalternatief zien als een afbeelding niet kan inladen door een fout in de code of een fout in de verbinding.
  • Zoekmachines gebruiken het tekstalternatief bij het beoordelen van de inhoud van een webpagina.

Schrijven van een tekstalternatief

Een tekstalternatief kan in een CMS meestal makkelijk worden toegevoegd in de mediabibliotheek of in de editor op de pagina.

Een tekstalternatief is alleen nuttig als de beschrijving goed passend is; De inhoud van het tekstalternatief hangt af van het doel van de afbeelding. Afbeeldingen zijn in 4 categorieën te verdelen:

  1. Informatief: Afbeeldingen die informatie toevoegen aan een pagina.
  2. Functioneel: Afbeeldingen die ook een link of knop zijn.
  3. Decoratief: Afbeeldingen die niet noodzakelijk zijn voor het begrijpen van de tekst of de pagina.
  4. Complex: Afbeeldingen die veel informatie toevoegen aan een pagina.

Let op: De invulling van een tekstalternatief hangt af van de context en kan zelfs per situatie verschillen voor dezelfde afbeelding. Bedenk bij het schrijven van het tekstalternatief altijd wat de bedoeling is van de afbeelding.

Informatieve afbeeldingen

Geef informatieve afbeeldingen een tekstalternatief dat beschrijft wat er op de afbeelding te zien is.

Functionele afbeeldingen

Geef functionele afbeeldingen een tekstalternatief dat beschrijft wat het doel van de link is of beschrijft wat het resultaat van de actie is.

Decoratieve afbeeldingen

Zorg dat hulptechnologieën decoratieve afbeeldingen kunnen negeren. Een leeg tekstalternatief is vaak al voldoende.

Complexe afbeeldingen

Geef complexe afbeeldingen naast een beknopte beschrijving in het tekstalternatief ook een langere beschrijving in de omringende tekst.

Code van een tekstalternatief

<img>-element

Het <img>-element is een veelgebruikte manier om afbeeldingen toe te voegen aan een website. Een tekstalternatief voor een <img>-element wordt gegeven met het alt-attribuut. Alle <img>-elementen moeten een alt-attribuut hebben.

De inhoud van het alt-attribuut is standaard niet zichtbaar.

<img src="logo-wcag.jpg" alt="WCAG.nl">

Bij een decoratieve afbeelding moet het alt-attribuut een lege waarde hebben (alt=""). Hierdoor kunnen hulptechnologieën de afbeelding negeren.

<img src="horizontale-lijn.jpg" alt="">

Geef bij complexe afbeeldingen naast een beschrijving in het alt-attribuut ook een langere beschrijving in de omringende tekst. Deze kan in de code worden gekoppeld aan het <img>-element. Gebruik hiervoor het aria-describedby-attribuut met het id-attribuut van het beschrijvende element.

<img src="infographic.jpg" alt="besluitboom voor het schrijven van tekstalternatief" aria-describedby="1">
<div id="1">
  <p>Afbeeldingen zijn in 4 categorieën te verdelen:</p>
  <ol>
    <li>Informatief</li>
    <li>Functioneel</li>
    <li>Decoratief</li>
    <li>Complex</li>
  </ol>
  ...
</div>

<svg>-element

Het <svg>-element is een container voor SVG-afbeeldingen. SVG-afbeeldingen zijn vector-based afbeeldingen. Deze afbeeldingen zijn hierdoor goed schaalbaar; ze kunnen worden vergroot zonder dat de kwaliteit verloren gaat.

Een tekstalternatief kan op een aantal manieren worden toegevoegd aan een <svg>-element. Bijvoorbeeld met het <title>-element of, bij voorkeur, samen met het aria-labelledby-attribuut.

<svg role="img">
  <title>WCAG.nl</title>
  ...
</svg>
<svg role="img" aria-labelledby="1">
  <title id="1">WCAG.nl</title>
  ...
</svg>
<svg role="img" aria-labelledby="2">
  ...
</svg>
<span id="2">WCAG.nl</span>

Als het <svg>-element puur decoratief is, gebruik dan het aria-hidden="true"-attribuut zodat het kan worden genegeerd door hulptechnologieën.

<svg aria-hidden="true">
  ...
</svg>

<figure>-element

Het <figure>-element is toegevoegd in HTML5. In het <figure>-element kunnen afbeeldingen worden gepresenteerd (maar ook andere content zoals tekst, quotes, codeblokken, enz.).

Voor het plaatsen van een afbeelding met het <figure>-element wordt een <img>-element in het <figure>-element geplaatst. Het <img>-element heeft hier ook het alt-attribuut nodig.

Het <figcaption>-element geeft een zichtbaar bijschrift de afbeeldingen in een <figure>-element. Het <figcaption>-element is optioneel.

<figure>
  <img src="teckel.jpg" alt="Teckel rennend met speelgoed">
  <figcaption>
    Mijn hond Jet
  </figcaption>
</figure>

Het <figure>-element is handig voor het presenteren van meerdere afbeeldingen in een groep.

<figure>
  <img src="teckel_1.jpg" alt="teckel rennend in het gras">
  <img src="teckel_2.jpg" alt="teckel staand in de zee">
  <figcaption>
    Mijn hond Jet
  </figcaption>
</figure>

Icon fonts of toolkits

Icon fonts zijn lettertypen met iconen in plaats van letters en cijfers. Icon toolkits bestaan uit een iconenbibliotheek met soms duizenden iconen. Deze manieren van het plaatsen van een icoon zijn populair omdat de iconen makkelijk met CSS kunnen worden vormgegeven en goed schaalbaar zijn.

Deze iconen zijn standaard nog niet goed toegankelijk. Ze hebben geen tekstalternatief en worden soms, net als gewone tekst, wél gepresenteerd door schermlezers. Zorg daarom dat het icoon wordt verborgen voor hulptechnologieën met het aria-hidden="true"-attribuut en geef het icoon een passend tekstalternatief.

Een tekstalternatief voor een icon font kan bijvoorbeeld worden toegevoegd met gewone tekst die dan wordt verborgen met CSS. Deze tekst is dan alleen voor hulptechnologieën te zien. Dit kan eventueel samen met het title-attribuut.

<i class="fas fa-calendar" aria-hidden="true" title="Datum"></i>
<span class="screenreader-text">Datum:</span>
<span>19 mei 2022</span>

Met de CSS:

.screenreader-text {
  position:absolute;
  left:-10000px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}

Dit is een voorbeeld met de icon toolkit Font Awesome. Kijk voor meer informatie ook eens op Font Awesome Accessibility: http://fontawesome.io/accessibility/ (Engelstalig)

Tips voor tekstalternatieven

Logo’s (of eventueel afbeeldingen met tekst) die ook een link zijn vallen in meerdere categorieën. In de categorie informatief én de categorie functioneel. Beschrijf in het tekstalternatief dan de tekst die op de afbeelding te zien is maar ook wat het doel van de link is.

Tot slot nog een paar tips andere voor het schrijven van een goed tekstalternatief:

  • Beschrijf de informatie die belangrijk is voor de context en het doel van de afbeelding.
  • Zorg dat de beschrijving beknopt maar relevant is (maximaal 150 tekens).
  • Gebruik in de beschrijving alle tekst die op de afbeelding te zien is.
  • Gebruik in de beschrijving alleen teksten zoals “foto van..”, “illustratie van..” of “schermafbeelding van..” als dit relevant is voor de context en het doel van de afbeelding.

Voorbeelden van tekstalternatieven

Voorbeeld 1: informatieve afbeelding

Een informatieve afbeelding (foto) van de brandweer.

<img src="image.png" alt="Een rode brandweerwagen met twee brandweerlieden die poseren met een waterslang">

Dit tekstalternatief beschrijft de informatie die belangrijk is voor de context en het doel van de afbeelding (kleur, aantal personen, actie).

Voorbeeld 2: functionele afbeelding

Afbeelding in een link

Een functionele afbeelding (logo in een link) van een logo die verwijst naar een andere website.

<a href="https://www.doetinchem.nl/">
  <img src="logo.png" alt="Gemeente Doetinchem, naar doetinchem.nl">
</a>

Dit tekstalternatief beschrijft wat er op te zien is (tekst) en waar de link naar verwijst (url).

Afbeelding in een knop

Een functionele afbeelding (icoon in een knop) van een print-knop.

<button type="button" onclick="window.print()">
  <img src="print.png" alt="Druk deze pagina af">
</button>

Dit tekstalternatief beschrijft wat er gebeurt als de knop wordt gebruikt (actie).

Voorbeeld 3: complexe afbeelding

Een complexe afbeelding (grafiek) van verkoopcijfers.

<img src="diagram.png" alt="Staafdiagram die de verkoopcijfers toont van 2021: Er is een stijgende trend in verkopen." aria-describedby="beschrijving">
<p id="beschrijving">
  Verkoopcijfers per kwartaal in 2021. Q1: €45.000, Q2: €60.000, Q3: €52.000, Q4: €70.000
</p>

Deze afbeelding heeft een beknopte beschrijving in het tekstalternatief, maar ook een langere beschrijving in de omringende tekst. De langere beschrijving is in de code gekoppeld aan de afbeelding.

Voorbeeld 4: decoratieve afbeelding

Een decoratieve afbeelding (illustratie in een link) van een link die verwijst naar categorie op een website.

<a href="categorie/spel.html"​>
  <img src="spel.jpg" alt=""​>
  Naar de categorie spelletjes
</​a​>

Deze afbeelding heeft geen tekstalternatief omdat de linktekst al alle benodigde informatie geeft om het linkdoel te kunnen bepalen. De afbeelding voegt verder geen informatie toe en is daarmee decoratief binnen de link.

Gerelateerde WCAG succescriteria

Functiebeperkingen in Nederland

In Nederland heeft ongeveer 20% van de bevolking een vorm van functiebeperking. Deze groep bestaat onder andere uit mensen met een auditieve beperking, cognitieve of neurologische beperking, fysieke of motorische beperking, visuele beperking of spraakbeperking.

Het is moeilijk om de echte cijfers te bepalen. Veel cijfers zijn een schatting en er is een overlap in cijfers doordat mensen meerdere functiebeperkingen kunnen hebben. De cijfers kunnen dus niet zomaar bij elkaar worden opgeteld.

FunctiebeperkingAantal mensen
BlindenOngeveer 76.000
SlechtziendenOngeveer 222.000
KleurenblindenOngeveer 750.000
Doven en slechthorendenOngeveer 1.500.000
Ernstige motorische beperkingOngeveer 472.000
Lichte verstandelijke beperkingOngeveer 68.000
DyslecticiOngeveer 850.000
LaaggeletterdenOngeveer 2.500.000
Schatting van het aantal mensen in Nederland met een functiebeperking volgens Digitoegankelijk in augustus 2019

Veel van deze mensen hebben dagelijks problemen met de toegankelijkheid van digitale informatie. Daarnaast is er een steeds groter wordende groep ouderen die moeite hebben met het gebruik van computers, smartphones, websites en apps.

Functiebeperkingen

Auditieve beperking

Auditieve beperkingen hebben te maken met een beperking aan het gehoor. Mensen met een auditieve beperking zijn bijvoorbeeld slechthorend of doof. Zij lopen mogelijk tegen problemen aan met informatie die alleen met geluid wordt overgebracht.

Voor een aantal mensen met een auditieve beperking is gebarentaal de primaire taal.

Voor mensen met een auditieve beperking:

  • Geef geluidsfragmenten een transcript.
  • Geef filmpjes ondertitels waarin ook alle belangrijke geluiden zijn opgenomen.

Cognitieve of neurologische beperking

Cognitieve en neurologische beperkingen hebben te maken met een beperking in het zenuwstelsel, inclusief de hersenen. Dit kan invloed hebben op de spraak, het gehoor, het zicht en het begrip. Dit zijn bijvoorbeeld mensen die ADHD, ASS, toevallen, een leerstoornis of een stoornis aan het geheugen hebben.

Voor mensen met een cognitieve of neurologische beperking:

  • Zorg dat automatisch bewegende, knipperende of scrollende content kan worden gepauzeerd, gestopt of uitgezet.
  • Gebruik geen elementen die meer dan 3 keer per seconde flitsen.
  • Zorg dat navigaties op iedere pagina in een vaste volgorde in de code staan.
  • Zorg voor duidelijke foutmeldingen als een formulier verkeerd is ingevuld.

Fysieke of motorische beperking

Fysieke of motorische beperkingen hebben te maken met een beperking in de beweging. In deze groep beperkingen vallen bijvoorbeeld mensen met onvrijwillige bewegingen (spasmen of tremors), coördinatieproblemen, verlamming, artritis en mensen met ontbrekende ledematen. Zij kunnen moeite hebben met de bediening van een website.

Voor mensen met een fysieke of motorische beperking:

  • Zorg dat alle functionaliteit te bereiken en bedienen is met het toetsenbord.
  • Zorg dat tijdslimieten kunnen worden uitgezet, aangepast of worden verlengd.
  • Zorg bij functionaliteit dat gebruik maakt van meerpuntsgebaren of padgebaseerde gebaren ook voor een alternatieve bediening die met 1 klik of tap te bedienen is.

Visuele beperking

Visuele beperkingen zijn een beperking aan het zicht. Mensen met een visuele beperking zijn bijvoorbeeld kleurenblind, slechtziend of blind. Zij lopen mogelijk tegen problemen aan met informatie die alleen met vormgeving wordt overgebracht.

Voor mensen met een visuele beperking:

  • Geef alle niet-tekstuele content een passend tekstalternatief.
  • Geef filmpjes een audiodescriptie als niet alle zichtbare informatie in geluid duidelijk wordt.
  • Gebruik niet alleen kleur om informatie over te dragen.
  • Gebruik genoeg contrast voor tekst en bedieningselementen.
  • Zorg dat tekst kan worden herschaald zonder dat er iets wegvalt of niet meer werkt en zonder dat horizontaal scrollen voorkomt.

Spraakbeperking

Spraakbeperkingen hebben te maken met het produceren van spraak dat goed verstaanbaar is. Dit gaat bijvoorbeeld over mensen die stotteren, die niet goed kunnen articuleren of mensen die helemaal niet kunnen spreken. Zij lopen mogelijk tegen problemen aan met functionaliteit die met stem- of spraak wordt bediend.

Voor mensen met een spraakbeperking:

  • Bied meer contactmogelijkheden dan alleen een telefoonnummer.

Digitale toegankelijkheid is voor iedereen

Een toegankelijke website heeft ook voordelen voor mensen zonder blijvende functiebeperking. Ondertitels zijn bijvoorbeeld ook handig als je een filmpje wilt kijken in een omgeving met veel lawaai. En met genoeg kleurcontrast kun je tekst beter lezen als er veel licht op je scherm valt.

Digitale toegankelijkheid vergroot ook de gebruiksvriendelijkheid voor iedereen, de vindbaarheid in zoekmachines en de compatibiliteit van een website.

Interessante links