Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Good intentions gone bad
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Eva Ferreira
May 23, 2024
Programming
0
280
Good intentions gone bad
JSHeroes 2024
Eva Ferreira
May 23, 2024
Tweet
Share
More Decks by Eva Ferreira
See All by Eva Ferreira
Criptografía para enamorados 💖
evaferreira
0
12
Cryptography for lovers 💖
evaferreira
0
38
Bulletproof your Design system
evaferreira
0
69
Bulletproof your Design System
evaferreira
0
160
Tales of Accessibility Failures
evaferreira
0
79
Tales of Accessibility Failures
evaferreira
0
230
La accesibilidad de todos los días - HackAcademy
evaferreira
0
160
Rescue the Dead Horse
evaferreira
0
150
De 45 a 85
evaferreira
0
110
Other Decks in Programming
See All in Programming
我々はなぜ「層」を分けるのか〜「関心の分離」と「抽象化」で手に入れる変更に強いシンプルな設計〜 #phperkaigi / PHPerKaigi 2026
shogogg
2
700
メッセージングを利用して時間的結合を分離しよう #phperkaigi
kajitack
3
510
生成 AI 時代のスナップショットテストってやつを見せてあげますよ(α版)
ojun9
0
310
今からFlash開発できるわけないじゃん、ムリムリ! (※ムリじゃなかった!?)
arkw
0
160
Nuxt Server Components
wattanx
0
190
Claude Codeログ基盤の構築
giginet
PRO
7
3.7k
AI 開発合宿を通して得た学び
niftycorp
PRO
0
180
Symfonyの特性(設計思想)を手軽に活かす特性(trait)
ickx
0
100
Tamach-sre-3_ANDPAD-shimaison93
mane12yurks38
0
190
Migration to Signals, Signal Forms, Resource API, and NgRx Signal Store @Angular Days 03/2026 Munich
manfredsteyer
PRO
0
180
Java 21/25 Virtual Threads 소개
debop
0
300
PHPで TLSのプロトコルを実装してみる
higaki_program
0
570
Featured
See All Featured
Skip the Path - Find Your Career Trail
mkilby
1
93
A Soul's Torment
seathinner
5
2.5k
How to Ace a Technical Interview
jacobian
281
24k
The State of eCommerce SEO: How to Win in Today's Products SERPs - #SEOweek
aleyda
2
10k
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
61
43k
Why Your Marketing Sucks and What You Can Do About It - Sophie Logan
marketingsoph
0
120
Google's AI Overviews - The New Search
badams
0
950
Git: the NoSQL Database
bkeepers
PRO
432
67k
How to audit for AI Accessibility on your Front & Back End
davetheseo
0
230
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
21
1.4k
Paper Plane (Part 1)
katiecoart
PRO
0
6.1k
Ten Tips & Tricks for a 🌱 transition
stuffmc
0
91
Transcript
Good Intentions, Gone Bad Eva Ferreira – JS Heroes, 2024
Not another “This is how you do a11y” talk Good
intentions gone bad. @evaferreira92
@evaferreira92 YOU DON’T HAVE TO LEARN FROM YOUR MISTAKES IF
YOU CAN LEARN FROM MINE
WARNING This is a work in progress. I will, most
definitely, keep on messing up. @evaferreira92
5 lessons 1. Accessibility personas 2. Simplest things first 3.
People mean well 4. Test, test, test! 5. Accessibility ownership
Lesson 1
A11y personas Understanding disabilities and assistive technologies
What is a disability? “Accessibility is for blind people”
Disability: A failed interaction between the environment and a person
with a medical condition.
Diverse group of people, a wide range of needs. @evaferreira92
16% of world’s population. has a permanent disability.
None
None
Assistive Technologies * Also known as AT
The most common assistive technology is…
Keyboard Visual and motor impairments
Lesson 2
Simplest things tend to have the biggest impact. I went
ALL IN into aria and screen readers
I wrongly prioritized screen readers over keyboard navigation Begin your
a11y journey with simple and impactful changes. @evaferreira92
Simple, impactful • Color contrast • Semantics • Keyboard navigation
Outlines Skip navigation links @evaferreira92
Outlines
None
@evaferreira92
But they are ugly! Yes, they are!
https://www.sarasoueidan.com Use outlines on your focusable elements
https://mabl.com
Skip navigation links
https://www.sarasoueidan.com
Skip navigation links
None
Lots impact, Low code.
Sometimes simple is not that simple “Code debt just called;
it wants your happiness back.” @evaferreira92
Prioritize Impact and easy to solve @evaferreira92
Prioritize 1. Big impact, easy to solve 2. Mix with
small impact, easy to solve Ideal for Fridays 3. Big impact, hard to solve 4. Small impact, hard to solve @evaferreira92
Lesson 3
People mean well … Most of the time.
Story time! Story Number 1
Aria-label all the things! The Infobae & the React Testing
Library stories @evaferreira92
@evaferreira92
Code
Non Screen Reader users
Screen Reader users
aria-label overrides values
Screen Reader users
Why?
@evaferreira92 https://webaim.org/blog/aria-cause-solution https://webaim.org/blog/aria-cause-solution
Story time! Story Number 2
“Every image should have an alt text!” @evaferreira92
Rules for alternative texts • The alt attribute is compulsory
• It can be empty if the image is decorative (alt=“”) • Do not be redundant • If it has an action, describe the action, not the image @evaferreira92
https://www.w3.org/WAI/tutorials/images/decision-tree
The SEO in the room And the story of how
every image had the same alt text. @evaferreira92
Lesson 4
Testing correctly Having 98/100 on Lighthouse won’t save you.
None
None
Manual tests @evaferreira92
Manual tests • Keyboard navigation • Screen readers @evaferreira92
What do we test? We test users’ stories. @evaferreira92
Can a user with [assistive technology] do [action]? @evaferreira92
Test users’ stories • Can a user with keyboard navigation
- create an account? • Can a user with a screen reader - add a product to the cart? • Can a user watch this video - using captions? @evaferreira92
Test for people. @evaferreira92
Automated tests WCAG
None
WCAG • Set of rules created by W3C a long
time ago. • Standard in the industry • What gives the foundation for a11y laws all around the globe • Different success criteria depending on target audience, target country, type of company, etc. @evaferreira92
Of course, always aim for no errors. @evaferreira92
Automated tools • Axe-core by Deque • Lighthouse • Mabl
• Storybook add-on @evaferreira92
Automated tools • Add these to your pipelines • CI/CD
should fail when requirements are not met. @evaferreira92
How many websites do you think pass with no errors?
5%? 20%? 40%?
4.1% WebAIM Million, 2024 https://webaim.org/projects/million
None
@evaferreira92
“It’s just too hard.” @evaferreira92
@evaferreira92
Lesson 5
A11y ownership Team effort
None
None
You cannot out-code bad design. Accessibility is a team effort.
So, You made a mistake. What happens when you mess
up.
You try again! * Easier said than done @evaferreira92
None
Mistakes are: • Temporal • Localized • Changeable
You don’t need to be always right. Aim for making
new mistakes instead of repeating old ones. @evaferreira92
You need to try, you need to care. @evaferreira92
Thanks! @evaferreira92