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
Rescue the Dead Horse
Search
Eva Ferreira
September 07, 2021
Programming
0
150
Rescue the Dead Horse
A talk about Accessibility Technical Debt
Eva Ferreira
September 07, 2021
Tweet
Share
More Decks by Eva Ferreira
See All by Eva Ferreira
Criptografía para enamorados 💖
evaferreira
0
11
Cryptography for lovers 💖
evaferreira
0
34
Bulletproof your Design system
evaferreira
0
64
Good intentions gone bad
evaferreira
0
270
Bulletproof your Design System
evaferreira
0
160
Tales of Accessibility Failures
evaferreira
0
72
Tales of Accessibility Failures
evaferreira
0
230
La accesibilidad de todos los días - HackAcademy
evaferreira
0
150
De 45 a 85
evaferreira
0
110
Other Decks in Programming
See All in Programming
フロントエンド開発の勘所 -複数事業を経験して見えた判断軸の違い-
heimusu
7
2.8k
HTTPプロトコル正しく理解していますか? 〜かわいい猫と共に学ぼう。ฅ^•ω•^ฅ ニャ〜
hekuchan
2
690
コマンドとリード間の連携に対する脅威分析フレームワーク
pandayumi
1
460
責任感のあるCloudWatchアラームを設計しよう
akihisaikeda
3
180
Data-Centric Kaggle
isax1015
2
780
AIエージェントのキホンから学ぶ「エージェンティックコーディング」実践入門
masahiro_nishimi
5
490
24時間止められないシステムを守る-医療ITにおけるランサムウェア対策の実際
koukimiura
1
110
AI巻き込み型コードレビューのススメ
nealle
2
450
dchart: charts from deck markup
ajstarks
3
1k
2026年 エンジニアリング自己学習法
yumechi
0
140
AI Agent の開発と運用を支える Durable Execution #AgentsInProd
izumin5210
7
2.3k
プロダクトオーナーから見たSOC2 _SOC2ゆるミートアップ#2
kekekenta
0
220
Featured
See All Featured
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
170
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
0
380
How to Align SEO within the Product Triangle To Get Buy-In & Support - #RIMC
aleyda
1
1.4k
Gemini Prompt Engineering: Practical Techniques for Tangible AI Outcomes
mfonobong
2
280
4 Signs Your Business is Dying
shpigford
187
22k
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
162
16k
GraphQLとの向き合い方2022年版
quramy
50
14k
Test your architecture with Archunit
thirion
1
2.2k
A designer walks into a library…
pauljervisheath
210
24k
jQuery: Nuts, Bolts and Bling
dougneiner
65
8.4k
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
26
3.3k
Abbi's Birthday
coloredviolet
1
4.8k
Transcript
Rescue the Dead Horse Eva Ferreira – Shift Conference, 2021
First trip since Feb. 2020
Hi! I’m Eva :)
Dead horse? @evaferreira92
Beating a Dead horse @evaferreira92
To waste time and effort trying to do something that
is impossible. “ ” Mr. Merriam-Webster
Tech Debt.
TECH DEBT.
Memes as a coping mechanism
@evaferreira92
@evaferreira92
@evaferreira92
@evaferreira92
@evaferreira92
@evaferreira92
@evaferreira92
None
What is Technical Debt? And… what isn’t Technical Debt?
¿Bad Code?
Bad Code = Lack Lack of knowledge, lack of caring,
lack of quality control
Bad code is usually more harmful than Techical Debt @evaferreira92
¿Tech Debt?
Technical Debt is a conscious Trade-off
It happens when we choose to gain something otherwise-unattainable immediately
in return for paying it back (with interest) later on. “ ” Mr. Harry Roberts
It happens when we choose to gain something otherwise-unattainable immediately
in return for paying it back (with interest) later on. “ ” Mr. Harry Roberts
The Theming Example
!important all the things
This is my garbage and I’m proud of it. @evaferreira92
@evaferreira92
@evaferreira92
Congrats! You have just created Technical Debt! Now… will you
repay? @evaferreira92
None
None
Consequences of not repaying • Accumulates interests • Snowball effect
• Team members are sad @evaferreira92
Repaying Tech Debt The Accessibility Part
An annual accessibility analysis of the top 1,000,000 home pages
How many passed a basic WCAG test?
WCAG includes (but not limited to) • Alternative texts for
images • AA Contrast ratios • Labels for inputs • Document language attribute • Buttons and links with discernable texts @evaferreira92
At least 20%? @evaferreira92 At least 10%? At least05%?
At least 20%? @evaferreira92 At least 10%? At least05%?
At least 20%? @evaferreira92 At least 10%? At least05%?
At least 20%? @evaferreira92 At least 10%? At least05%?
Only 2,6% passed. @evaferreira92
Most common errors • Lack of alternative texts for images
• Non-compliance color contrasts • Lack of labels for inputs • Lack of document language attribute • Buttons and links without discernable texts @evaferreira92
<html lang="es">
Fun facts “Despite being 2021, 14,501 home pages had <marquee>
and 341 home pages had blinking content (<blink> or text-decoration: blink).” https://webaim.org/projects/million/
Why does this happen? Lack of accessibility is more often
than not, a conscious trade-off.
None
How do we begin repaying? Repaying accessibility technical debt
Current Tech Debt Improvements to current a11y bugs
Spare time to improve it • Small, well-defined tasks
15% of sprint • Fix bugs • Rebuild broken components • Build new features Skip navigation, etc. @evaferreira92
Track and document @evaferreira92
None
You can’t repay what you don’t acknowledge @evaferreira92
Avoid creating more (Accessibility Technical Debt)
Long term warning! The following recommendations might take soooome time
Cultural change in the company You need people who care.
@evaferreira92
Update processes • Automated tests Built into CI •
Manual tests • QA Process • Internal demos with Screen Reader @evaferreira92
Design Systems • Fix a11y here! Colors, contrast, font-sizes,
font families Labels and alts • Whatever what Brad Frost and Jina Anne say @evaferreira92
None
https://bradfrost.com/blog/post/enforcing-accessibility-best-practices- with-automatically-generated-ids/ by Brad Frost
@evaferreira92
Hire Front-end developers @evaferreira92
Hire Front-end developers @evaferreira92
No code can fix bad design. If the design is
inaccessible, so is the website.
Bad UX flows
None
None
None
@evaferreira92
Team work It’s not 1999 with webmasters doing the whole
thing anymore
None
You can’t avoid Tech Debt But you CAN avoid putting
the burden on users with disabilities
Thank you! @evaferreira92