Description
An accessible dark mode toggle button employing ARIA attributes for screen reader users.
                
Additionally, visual cues (icon, on/off text) are provided for sighted users.
Accessibility
- The ARIA-pressedattribute indicates the button state to screen readers.
- The ARIA-hiddenattribute hides the SVG icon and CSS content text from screenreaders.
- Keyboard navigation via the Tabkey focuses the button.
CSS
- CSS variables are used for the dark and light themes.
- The contentproperty prints 'on' or 'off' according to the state of the button.
JavaScript
- Button state is saved to local storage, so the chosen theme persists.
- ES6 (no transpilation to ES5)
Sources
- ARIA-pressedinformation (and more) from Inclusive Components/Toggle Buttons
- 'Moon' icon from Free Box Icons (click SVG tab for code))
Testing
Tested on Windows 10:
- Chrome
- Firefox
- Microsoft Edge