<AccessibleCSSinJS />
Maya Shavin
Senior Software Engineer
data:image/s3,"s3://crabby-images/d809b/d809b1df9728f8e975aea8e6dd5271a8b62955a9" alt=""
In this talk
- ✨ A quick recap of accessibility
- 😰 Challenges & Solutions
- ✅ Tools
- 🚀 Developing an accessible mindset
data:image/s3,"s3://crabby-images/846eb/846ebee8d608fb3c918b3e3ae093888dd58f6ff8" alt=""
data:image/s3,"s3://crabby-images/02d8d/02d8df505609c5da3592b2f7be9dfdc295df5244" alt=""
What is accessibility?
data:image/s3,"s3://crabby-images/24b83/24b832d347229148f033bab1e16ea2fcf536bbdb" alt=""
See
🦻
Hear
data:image/s3,"s3://crabby-images/b9872/b987284bac03c1af53910bc0334ee69095493d16" alt=""
Understand
⌨️
Use/Navigation
data:image/s3,"s3://crabby-images/40c8b/40c8b6415e18a586e9b2722497202bc7902eac02" alt=""
data:image/s3,"s3://crabby-images/24b83/24b832d347229148f033bab1e16ea2fcf536bbdb" alt=""
See
🦻
Hear
data:image/s3,"s3://crabby-images/b9872/b987284bac03c1af53910bc0334ee69095493d16" alt=""
Understand
⌨️
Use/Navigation
Standards
Web Content Accessibility Guidelines
Perceivable
Operable
Understandable
Robust
WCAG 2.1
A
AA
AAA
- Web content
- Assist Technologies (WAI-ARIA)
- Web technology (Flash, video, audio)
- Visually impaired
- Cognitive disorders
Accessibility is HARD
Accessibility in React is HARD
Accessibility in React is COMPLEX
But NOT hard!
Accessibility is COMPLEX
Accessibility in components
With or without CSS-in-JS
Semantic HTML Tags
Focus management
Screen Reader support (WAI-ARIA etc)
Dynamic Content
Accessibility in components
Magnification support (200%, 400%)
Using Sematic HTML Tags
Landmarks/Regions
& Headings
table
h1-h7
article
header
footer
nav
dialog
button
a
input
data:image/s3,"s3://crabby-images/933d6/933d6ba7363c30dd2bf51c2a89cb1d7861cb7adc" alt=""
data:image/s3,"s3://crabby-images/b0692/b069212b529beeff6d295fa68d3642851eb5c903" alt=""
data:image/s3,"s3://crabby-images/76f75/76f75ea3a866e586ae10ae661a21e836daee128a" alt=""
data:image/s3,"s3://crabby-images/1e6c5/1e6c588e3a0c5fa821dc69d5ad74c513a52301be" alt=""
JS
CSS
Parse CSS
Inject to Stylesheet
stylesheet.insertRule
Browser
HTML Paint
load
download
data:image/s3,"s3://crabby-images/a138c/a138c0db4068ed437fa79aa7592b185e2bd33980" alt=""
data:image/s3,"s3://crabby-images/a138c/a138c0db4068ed437fa79aa7592b185e2bd33980" alt=""
✅ Keep the heading order structure (h1 - h7)
✅ Use CSS order to re-arrange the appearance
Focus management
- Order of focus?
- Auto-focus ?
- Keyboard navigation flow ?
- Think logical
- Use refs, DOM API (.focus())
- Use tabIndex, order
Screen Reader support (WAI-ARIA)
<button
aria-label="Place an order"
>
Order
</button>
<button
aria-label="Place order button"
>
Order
</div>
✅
Place an order, button
❌
Place order button, button
aria-label vs aria-labelledby
<dialog role="dialog" aria-label="Sample Modal">
<header>
<h2 id="header-title">
Sample Modal
</h2>
</header>
<main>
<p id="description">
This is the content
</p>
</main>
<footer>
<button aria-label="close dialog">
Close
</button>
</footer>
</dialog>
<dialog role="dialog" aria-labelledby="header-title">
<header>
<h2 id="header-title">
Sample Modal
</h2>
</header>
<main>
<p id="description">
This is the content
</p>
</main>
<footer>
<button aria-label="close dialog">
Close
</button>
</footer>
</dialog>
data:image/s3,"s3://crabby-images/01ccd/01ccda0266b8dfae6930bb4c33490cff446e5571" alt=""
<Badge>
Item Two
<BadgeIcon
aria-label="Badge count 6"
role="status"
>
6
</BadgeIcon>
</Badge>
Item two, badge count 6
✍️ Visible and understandable label
✅ Clear ARIA role when needed
👷♂️ Interactive value (aria-disabled, aria-selected, etc)
🗒️ Concise description as hints (don't use title)
Working with screen reader
3 out of 5 tasks completed
Add to list, button
Dynamic content with aria-live & aria-atomic
data:image/s3,"s3://crabby-images/01ccd/01ccda0266b8dfae6930bb4c33490cff446e5571" alt=""
<Badge className="v-badge theme--dark">
Item Two
<BadgeIcon
aria-atomic="true"
aria-live="polite"
aria-label="Badge count 6"
role="status"
>
6
</BadgeIcon>
</Badge>
100% accessible in combination with lazy loading component
Magnification support
200% - 400% Zoom
Text readability
Contrast/Color
Layout consistency
===
Responsiveness
Use media query & JS calculation
Color combination 🎨
data:image/s3,"s3://crabby-images/e1cdc/e1cdcb088f94abd03c29fafa320a635f0730c69a" alt=""
Tools
Think Accessibility FIRST
And split the CSS code
Building an accessible component
What is component's type?
Focus & navigation behavior
Component internal flow and external flow
Component stylings
Interactivity
Take action 📢
- ✅ Be intuitive & organized
- ✅ Apply WAI-ARIA approriately
- ✅ Image Alt & description whenever needed!
- ✅ Pay attention to color combination!
- ✅ Test accessibility with Axe, Accessibility Insights or Lighthouse
- ✅ Manual testing with Screen reader and Screen magnifier
data:image/s3,"s3://crabby-images/0d697/0d697fb310b3cb8b66eb50f7a3a76c16ab3ae058" alt=""
data:image/s3,"s3://crabby-images/bf6f1/bf6f13fb5fd8015fdf795a3f7cf12563552a701e" alt=""
data:image/s3,"s3://crabby-images/ea66f/ea66fda8a44c3e610184b534a82bd4a10de8f059" alt=""
Thank you
@mayashavin
mayashavin.com
Accessible CSS in JS?
By Maya Shavin
Accessible CSS in JS?
- 578