Web Accessibility
Hacker Way
Why?
Because we want to empower EVERY person on the planet
When we design our websites to be accessible, we make our websites better for EVERYONE
It is required by law
3 steps to be 80% accessible
Website is usable with keyboard only
Smart focus management
Website can be used with screen reader
Website is usable with keyboard only
focus outline is visible
no extra/unnecessary tabstops
no tabstop traps
Smart focus management
set focus on appropriate elements after user actions
restore focus to appropriate elements after user actions
make tab order user friendly
Website can be used with screen reader
When element gets focused, screen reader should provide meaningful information
Min bar: Make it work with Chrome + NVDA
The best ARIA is no ARIA
Add aria-* tags if needed (to help screen reader)
Tips & Tricks
use common sense and your own judgement
use native HTML elements when possible
only 30% can be verified by tools
Ibiza Tips & Tricks
[Impl] KeyboardShortcutHandler.ts
[QUnit] KeyboardShortcutHandler.test.ts
[Selenium] KeyboardShortcutTests.cs
use waitForBindings() to set focus
use Interactions.DismissHandler to restore focus
Why keydown?
keypress does not work for special keys (e.g., ESC, ARROWS)
with keyup you cannot detect two keys (e.g., ? == SHIFT+/)
if needed: add separate handlers
Handling Keyboard
$element.on(EventTypes.keydown, evt => {
if (evt.which === Util.KeyCode.Enter
&& KeyboardHelper.getModifierKeys(evt) === ModifierKeys.None) {
// do stuff
return false;
}
});
$element.on(EventTypes.keydown, evt => {
if (evt.which === Util.KeyCode.Enter
&& KeyboardHelper.getModifierKeys(evt) === ModifierKeys.None) {
// do stuff
evt.stopPropagation();
evt.preventDefault();
}
});
Unit testing keyboard
// emulate pressing key
TypingEmulator.writeKeyCode(element, KeyCode.H);
// checking for focused element
strictEqual(document.activeElement, element2);
// checking for focused element async
TestHelper.strictEqualAsync(
() => document.activeElement, element2);
UI testing keyboard
// emulating user key press
webDriver.SwitchTo().ActiveElement().SendKeys("h");
// might be flakey if executed right after key action
Assert.IsTrue(IsFocused(element));
// better, async assert
webDriver.WaitUntil(() => IsFocused(element));
// checking for focus with Selenium
bool IsFocused (IWebElement element) {
return Equals(webDriver.SwitchTo().ActiveElement(), element);
}
// checking for focus with JavaScript
bool IsFocused (string element) {
return Convert.ToInt32((webDriver as IJavaScriptExecutor)
.ExecuteScript("return document.activeElement == " + element)) == 1;
}
Tools
Chrome Accessibility Audit
Keros (aka KFC = Keros For Chrome)
http://toolbox/keros
AXE
http://www.deque.com/products/axe/
Accessibility
=
Performance First
References
?
Questions
Web Accessibility Hacker Way
By Jakub Jedryszek
Web Accessibility Hacker Way
If you would print entire Web Accessibility specification, and stack it, it would be higher than CN Tower in Toronto (553 meters = 1814.3 feet). However, there is a way how you can fulfill 80% of this specification with 20% of effort, without even reading it. Let's find out what's the web accessibility hacker way
- 1,377