7. Bedienbaar
Om een computer te bedienen heb je een toetsenbord en een muis. Maar die heb je niet altijd en niet iedereen kan een muis of toetsenbord bedienen. Om die reden moet de website ook bruikbaar zijn zonder muis of toetsenbord.
7.1 Bedienbaar met toetsenbord en muis
Let op: Mac-gebruikers moeten de instellingen voor het toetsenbord aanpassen om te kunnen testen met het toetsenbord.
Omschrijving
Mensen die blind zijn kunnen geen muis gebruiken, want ze zien niet waar de muis zich op het beeldscherm bevindt. Zij zijn dus voor de invoer aangewezen op het toetsenbord. Ook voor mensen met motorische problemen of mensen met RSI kan het gebruik van de muis moeilijk zijn.
Een groot verschil tussen het werken met een toetsenbord en een muis is dat het werken met een toetsenbord in principe altijd lineair is. Met een muis kun je direct op een link klikken, waar die ook op de pagina staat. Met een toetsenbord begin je normaal gesproken linksboven en moet je alle links een voor een langs om te komen bij de link die je aan wilt klikken.
Succescriteria
- 1.3.2 Betekenisvolle volgorde (niveau A)
- 2.1.1 Toetsenbord (niveau A)
- 2.1.2 Toetsenbordval (niveau A)
- 2.4.1 Blokken overslaan (niveau A)
- 2.4.7 Focus zichtbaar (niveau AA)
Toepassen
Alles moet bereikbaar zijn met het toetsenbord. Je kunt dit zelf eenvoudig testen. Toets daarbij het volgende:
- De toetsen tab, enter en de pijltjestoetsen werken naar verwachting
- Alles is bereikbaar
- Focus is zichtbaar
- Tabvolgorde is logisch
- Alles is bruikbaar
Het testen van de toetsenbordtoegankelijkheid is de makkelijkste en een van de belangrijkste testen op toegankelijkheid.
Regelmatig kom je tegen dat iets niet toegankelijk is met het toetsenbord. Dat gaat vaak om verkeerd geïmplementeerd JavaScript. Bijvoorbeeld bij het tabben door de site blijf je haken op een tekst, waar dit script onderzit. Dat heet een toetsenbordval.
Een screenreader kan de content ook niet-lineair opvragen. De gebruiker kan bijvoorbeeld een koppenlijst opvragen en direct naar een kop in de content springen. Of een linklijst opvragen met alle hyperlinks. In feite zijn dit de mogelijkheden om te scannen, iets wat de ziende persoon met zijn ogen doet.
Dat betekent wel weer dat het belangrijk is dat alle koppen zijn opgemaakt met kopstijlen en dat kop- en linkteksten betekenisvol zijn.
7.2 Tabindex
Met het attribuut tabindex manipuleer je de tabvolgorde binnen een website.
Normaal gesproken zijn alleen links en formulierelementen tabbaar. De tabvolgorde is bepaald door de volgorde waarin de elementen in de code staan.
Met tabindex kun je aan deze tabnavigatie wijzigen: je kunt een element toevoegen, verwijderen of de plek in de tabvolgorde wijzigen.
Waardes voor de tabindex
De tabindex heeft als waarde altijd een geheel getal (integer). Er zijn 3 manieren om het te gebruiken:
- positief getal, bijvoorbeeld tabindex = "1": geeft een element een expliciete tabvolgorde en overschrijft daarmee de standaard tabvolgorde binnen een pagina. Gebruik deze nooit.
- tabindex= "0": hiermee maak je een element tabbaar, op de plek waar het element in de code staat. De tabvolgorde wordt dus verder niet aangepast.
- tabindex= "-1": hiermee haal je een element juist uit de tabvolgorde. Het is niet meer 'tabbaar'.
tabindex ="1" (of elk geheel getal boven 0)
Een positieve waarde voor de tabindex is altijd verkeerd. Vermijd dit dus altijd. Wil je de tabvolgorde veranderen, verander dan de volgorde van de elementen in de broncode.
tabindex ="0"
Soms wil je een ander element dan een link of formulierveld ook meenemen in de tabvolgorde, bijvoorbeeld op een p-element voor een instructie bij een formulier:
<p tabindex="0">Heb je een vraag of opmerking voor ons, gebruik onderstaand formulier. Je kunt natuurlijk ook bellen of mailen, net wat je makkelijk vindt.</p>
tabindex ="-1"
Als tabindex wordt gebruikt is dat meestal om hiermee een element uit de tabnavigatie te halen. Dat kan met de waarde "-1".
Hieronder een voorbeeld waarbij een veld uit de tabvolgorde wordt gehaald:
<input type="text" id="input_extra" name="feedback[extra]" value="" tabindex="-1">
In dit geval is het een veld dat bedoeld is om spammers te weren en juist niet ingevuld moet worden.
7.3 Logische tabvolgorde
Het is belangrijk dat de volgorde van de interactieve elementen bij het tabben gelijk is aan de visuele volgorde.
Met interactieve elementen bedoelen we bijvoorbeeld links, buttons en invoervelden.
In het voorbeeld hieronder heeft de webbouwer om onbekende reden het veld voor geslacht (Aanhef) uit de leesvolgorde gehaald. Aangezien dit een verplicht veld is, maakt dit het formulier volledig onbruikbaar voor mensen die aangewezen zijn op een toetsenbord.
7.4 Skiplinks naar onderdelen van je site
Omschrijving
Sommige mensen kunnen geen muis gebruiken en zijn aangewezen op enkel het toetsenbord. Voor hen is het belangrijk dat zij blokken content kunnen overslaan. Bijvoorbeeld dat ze direct bij de hoofdinhoud van een pagina kunnen springen.
Blokken overslaan kan goed met zogenaamde skiplinks. Normaal zie je die niet, maar als je door de site tabt worden die wel zichtbaar. Probeer dat maar eens op onze site, www.internetacademy.nl. Als je met de tabtoets door de site gaat, wordt de skiplink 'Naar inhoud' zichtbaar.
Deze zichtbaarheid is handig voor toetsenbordgebruikers. Gebruikers van screenreaders kunnen zo ook makkelijk delen van de pagina overslaan.
Succescriterium
- 2.4.1 Blokken overslaan (niveau A)
Toepassen
De skiplinks worden in de template van je website ingebouwd. Zorg dat de skiplink de 1e link is.
7.5 Zichtbaar zijn waar je bent
Omschrijving
Succescriterium 2.4.7 geeft aan dat zichtbaar moet zijn waar je met de tab-toets in de site bent. Normaal geeft je browser een lijntje om de link waar je op dat moment bent (de focus), zoals hieronder is te zien (lijntje om NCDT 2022). Webbouwers halen dit lijntje soms weg en dat is niet de bedoeling.
Succescriterium
- 2.4.7 Focus zichtbaar
Toepassen
- Ga met je tabtoets door je site en controleer of je steeds kunt zien waar je met de tabtoets zit.
- Doe dit door de hele pagina totdat je weer bij het begin bent.
- Zie je de focus niet, dan is de focus mogelijk verwijderd door de webbouwer.
Let er ook op dat de focus zichtbaar is bij aanklikbare afbeeldingen.
7.6 Kopstijlen voor koppen
Omschrijving
Koppen geven een pagina betekenis en structuur. Vandaar dat het belangrijk is dat de kopteksten betekenisvol zijn en dat je ook de juiste kopstijlen gebruikt.
Succescriteria
- 2.4.2 Paginatitel (niveau A)
- 2.4.6 Koppen en labels (niveau AA)
Toepassen
In ons e-book webcontent geven we een uitgebreide uitleg hierover in het hoofdstuk headings voor betekenisvol opmaken.
Algemene adviezen:
- Zorg voor een <h1> op elke pagina
- Zorg voor unieke <h1>-tekst
- Pas heading alleen toe als de tekst ook echt een kop is
- Voorkom lege headings
- Hou de juiste volgorde van de niveaus aan. Bijvoorbeeld ga niet van <h2> naar <h4> of van <h2> naar <h1>.
Uitzondering: headings bij gebruik van modals
Als je werkt met een modal dan zie je bij de controle van de pagina dat de koppen van de modal ook staan in de pagina waar de modal geopend wordt. Omdat een modal meestal ook een h1 heeft, zie je 2 keer een h1 in de code. Dit is geen probleem, want in principe krijgt de schermlezer alleen de headings van de pagina waar die is, dus van de modal óf van de hoofdpagina.
7.7 Landmarks (page regions)
Omschrijving
Eerst maar eens uitleggen wat het is. Een landmark of page region is HTML5-code waarmee je de betekenis van een stukje content kunt aangeven. Bijvoorbeeld <nav> betekent een navigatie-onderdeel, vaak een menu. Zie het code-voorbeeld hieronder.
<nav>
<ul>
<li><a href=”/”>Home</li>
<li><a href=”/contact”>Contact</li>
[nog wat menu-items]
</ul>
</nav>
Gebruikers van een schermlezer gebruiken deze landmarks. Ze kunnen alle landmarks opvragen en krijgen zo een goede indruk van de lay-out van de pagina. En ze kunnen zo direct springen naar het stukje content dat ze zoeken.
Door een landmark om een blokje content te plaatsen, krijgt dit stukje content een rol. Dit is de ARIA role.
Bij de landmark <nav> hoort de rol “navigation”. Voor toegankelijkheid zijn deze rollen belangrijk. Je vindt deze rollen ook terug in de accessibility tree.
Succescriteria
- 1.3.1 Info en relaties
- 2.4.1 Blokken omzeilen
Alle landmarks en rollen
Met HTML5-landmarks verdeel je een webpagina in verschillende onderdelen (regions). Belangrijke landmarks zijn:
- <header>: voor de bovenkant de site, zoals het logo, de skiplink en de zoekfunctie
- <nav>: voor het menu
- <main>: bevat de primaire content van de pagina (het onderwerp van de pagina)
- <aside>: bevat de secundaire content, zoals een blokje met links
- <footer>: het ondermenu en eventueel nog andere footer-elementen
De header, main en footer kunnen allemaal slechts 1 keer voorkomen. De andere landmarks kunnen meerdere keren voorkomen, zoals een <nav>.
De landmarks en rollen zijn:
HTML-landmark | ARIA-role |
---|---|
<header> | role="header" |
<main> | role="main" |
<footer> | role="contentinfo" |
<aside> | role="complementary" |
<form> | role="form" |
<section> | role="region" |
N/A | role="search" |
Zoals je ziet is er voor de zoekfunctie (“search”) geen aparte HTML5-landmark, maar met role=”search” kun je deze wel beschikbaar maken voor schermlezers.
Gebruik zo weinig mogelijk landmarks. Ze zijn bedoeld om snel naar de belangrijkste onderdelen van een pagina te kunnen gaan. Teveel landmarks maken dat ingewikkeld.
Testen
Landmarks en hun rollen zijn belangrijk voor schermlezers. Het stelt hen in staat snel naar de primaire content of naar een menu te springen.
Je kunt testen of ze aanwezig zijn met WAVE. Met Inspector zie je bij de landmarks ook de bijbehorende rollen.
Verder lezen
- Using HTML landmark roles to improve accessibility
- Landmarks and Landmark Regions
- Landmark cheatsheet
7.8 Hyperlinks
Omschrijving
Bij een link moet duidelijk zijn waar de link naar toegaat, anders wordt het een grote verrassing als je er op klikt.
Succescriteria
- 2.4.4 Linkdoel, in context (niveau A)
Toepassen
Zie de uitleg in het hoofdstuk hyperlinks: verbindingen leggen in ons e-book Webcontent.
7.9 Plaatsaanduiding met rechts en links
Omschrijving
Het lijkt zo logisch om te schrijven 'In het submenu aan de rechterkant kunt u (...)', maar als de website responsive is zal dit vaak niet rechts zijn maar eronder of erboven. Ook blinde gebruikers weten niet waar de 'rechterkant' is, want links of rechts bestaat niet in spraak- of braille-uitvoer.
Succescriteria
- 1.3.3 Zintuiglijke eigenschappen (niveau A)
Toepassen
Verwijs niet met rechts, links of soortgelijke aanduidingen zoals een 'horizontaal menu'. Onder en boven kun je wel gebruiken.
Hieronder een voorbeeld waarbij verwezen wordt naar een horizontaal menu; voor mobiele gebruikers en gebruikers van een screenreader is het niet duidelijk welk menu bedoeld wordt.
7.10 Instellen toetsenbordtoegankelijkheid op een Mac
Op een Apple-computer moet je de browser aanpassen om te kunnen testen op de toetsenbordtoegankelijkheid.
- Firefox:
- Systeemvoorkeuren (van de Mac) ▸ Toetsenbord ▸ Toetscombinaties
- Selecteer onderaan het voorkeurenvenster de optie Verplaats focus tussen regelaars met toetsenbordnavigatie. In macOS Mojave of lager kies je Alle regelaars.
- Chrome:
- Voorkeuren ▸ Toegankelijkheid
- Selecteer Navigeren op pagina's met een tekstcursor (Gebruik de sneltoets F7 om browsen met navigatietoetsen aan of uit te zetten).
- Safari:
- Voorkeuren ▸ Geavanceerd ▸ Tabtoets markeert elk onderdeel op de webpagina