Web Accessibility and React
Andy Ernst
Software Engineer at Axon
https://slides.com/andyernst/a11y
Goal of this talk
- What
- Who
- Why
- How
- Where
- Covering basics only
data:image/s3,"s3://crabby-images/dd638/dd6387916b8030c5cbd455cd7796effa0c407429" alt=""
What is Accessibility?
- Allowing people to see and use your website
- Inclusive website for everyone
- Called a11y for short
Who are we talking about?
- 6% cognitive
- 4% seeing color
- 2% no or little vision
- 2% hearing
- 8% motor
http://www.interactiveaccessibility.com/accessibility-statistics
Why improve accessibility?
- More users
- Right thing to do
- Otherwise you'll get sued
- Easier to do early
- Better experience for everyone
data:image/s3,"s3://crabby-images/91e9b/91e9bda6171a0f1313e008d034d3c40bbfe3424f" alt=""
fix it now!
User difficulties
-
Dyslexic
-
Low vision, color blind
-
Hearing-impaired
-
Motor impaired
-
Non-sighted
data:image/s3,"s3://crabby-images/dc143/dc143c21cf2e0706e276d2c857c2266227963bbb" alt=""
Sarah
- Dyslexia
-
Difficulty with
- reading
data:image/s3,"s3://crabby-images/37cb0/37cb009d8085fefc9360a54cc96c3ade2e8dd86a" alt=""
http://geon.github.io/programming/2016/03/03/dsxyliea
Fixes
- Limit text width
- Min text size 14px, 1em or rem preferred
- Call outs
- Straightforward language
- Spelling tolerance
Also helps when
- Distracted
- Skimming
- Non-native language
- Good design
data:image/s3,"s3://crabby-images/3ac84/3ac84b3780f389b258bd100eb599adbe1a6ccd3b" alt=""
Allan
- Low vision
- Color blind
-
Difficulty with:
- small fonts
- colors
data:image/s3,"s3://crabby-images/37b8b/37b8b0564443914a2f4e529a4b3a17fa605909a4" alt=""
Fixes
- Avoid small fonts
- Allow zooming
- Multiple cues
- Test with aXe
- Test color with camera
user-scalable=no
data:image/s3,"s3://crabby-images/4d856/4d8563faf009daebe809e2f321bdf8e30080ecb8" alt=""
Also helps when
- Forgot glasses
- Glare on screen
- Old monitor
Liz
- Cannot hear well
-
Difficulty with:
- any audio
- unclear/multiple audio
Fixes
- Multiple contact methods
- Avoid audio-only cues
- Add captioning/transcripts
- Volume/speed adjust
auto-play?
data:image/s3,"s3://crabby-images/4d856/4d8563faf009daebe809e2f321bdf8e30080ecb8" alt=""
Also helps when
- Noisy environment
- Non-native language
Julie
- Cannot use a mouse
-
Difficulty with:
- bad websites
- SPAs
data:image/s3,"s3://crabby-images/f8dc2/f8dc244b67d62f6c229cae113e575f4dfcafa4ae" alt=""
DEMO
Keyboard-only navigation
Fixes
- Keyboard testing
- Keyboard clicking
- Proper HTML
- Large touch targets
-
Careful with modals and fancy things
- use a library
Avoid
:hover, :focus {
outline: none;
}
Don't override
Instead:
data:image/s3,"s3://crabby-images/4d856/4d8563faf009daebe809e2f321bdf8e30080ecb8" alt=""
:hover, :focus {
border-left: 2px solid blue;
}
?
But if you have to
Avoid
tabindex > 0
tabindex="1"? tabindex="2"? tabindex="5"?
data:image/s3,"s3://crabby-images/da762/da7628fdb0fa9f3e23dac9c540e54685c04c845f" alt=""
tabindex="0"
tabindex="-1"
focusable
js-focusable
Instead:
Use native HTML
Also helps when
- On bus with phone
- Holding something
- Web forms
data:image/s3,"s3://crabby-images/a1b5f/a1b5f0a08c017978e525578c32f9477c83c7c2e6" alt=""
Brian
- Cannot see
-
Difficulty with:
- poor HTML structure
- bad user-flow
- SPAs
data:image/s3,"s3://crabby-images/d1dc2/d1dc292127d5050a8967054d1c759eee26ae69f5" alt=""
data:image/s3,"s3://crabby-images/3db9e/3db9e7f1f745fb695c3c248d7990e5b3d5dbb3ec" alt=""
data:image/s3,"s3://crabby-images/e1222/e122296f51e84c9e7b4552060042c97bf79d0a17" alt=""
DEMO
data:image/s3,"s3://crabby-images/e1222/e122296f51e84c9e7b4552060042c97bf79d0a17" alt=""
⌘ + F5
VoiceOver is Installed on all iPhones and macs
See training in System Preferences > Accessibility > VoiceOver > Open Training
Fixes
- HTML hierarchy
- Proper HTML elements
- Meaningful link names
- Alt text
- Aria-role, aria-attribute, visuallyhidden
ARIA whaaaaaat?
- Many ARIA roles and attributes
data:image/s3,"s3://crabby-images/5f204/5f2047d8677e8b25eab52e92b82558d01a34b069" alt=""
data:image/s3,"s3://crabby-images/a0cd0/a0cd095a9ce2cbd1010cb9f13635d19e20db12f9" alt=""
aria-label
aria-hidden
aria-live
data:image/s3,"s3://crabby-images/b00cd/b00cd6de0bb5eb2f17b94c229ba2a9d8c96b1510" alt=""
data:image/s3,"s3://crabby-images/19b34/19b3457117853ad0ab7c558f325f3aebe2d077c4" alt=""
Aria best hits
-
role="button"
-
aria-label="Search articles"
-
aria-hidden="true"
-
aria-live="assertive"
Visually hidden
.visuallyhidden {
border: 0;
clip: rect(0 0 0 0);
position: absolute;
height: 1px;
width: 1px;
margin: -1px;
overflow: hidden;
padding: 0;
}
ARIA
- HTML > role/aria
- Aria/role > visuallyhidden hints
- Test it!
<span role="checkbox"
aria-checked="true"
tabindex="0">
label name
</span>
data:image/s3,"s3://crabby-images/0b453/0b453c08c027649b797f8b94f50223fb882dad8e" alt=""
Semantic HTML is always best!
Also helps when
- Good HTML helps everyone
- Crawlers
A11y in React
- Easily keep in sync
- Aria uses dashes
- Escape hatch for focus management
<article
className={classes}
role="listitem"
aria-owns="open-product-details">
A11y in React
- Don't reimplement!
- Use tested components
- Use jsx-a11y or React-aXe
data:image/s3,"s3://crabby-images/44cb3/44cb38b5208301a1ac0fc434235f330bbaff1f28" alt=""
Should always do
-
Think of users
-
Test with keyboard
-
Test with a screen reader
-
Test with aXe
The perfectly accessible website
Pure HTML, no CSS, no JS
But we break it with nice styles and JS functionality
Recap
- POUR
- Perceivable
- Operable
- Understandable
- Robust
data:image/s3,"s3://crabby-images/b8906/b890640cf3846a55da87f0ac03ad87e6fb4ff23c" alt=""
Accessible website? You win!
Resources
- Free Udacity course
- A11y posters
Resources
- Definitions
- Examples
- Personal stories
Questions?
Andy Ernst
aernst@axon.com
https://slides.com/andyernst/a11y
Web Accessibility: the web is for everyone
By Andy Ernst
Web Accessibility: the web is for everyone
A talk about the basics of web accessibility and how improving accessibility helps all users. This includes a demonstration of tools to test and troubleshoot these issues and how they affect React developers.
- 412