I am a math tutor currently helping middle and high school students master common math concepts, and getting them prepared for the SAT and ACT tests.
I am also a computer programming enthusiast, especially interested in data analytics using Python, SQL and R.
I previously worked in international marketing and product development for Stanley Black & Decker, for more than 25 years.
👋 Contact me at mario@mariosanchez.org.
Switch to dark theme for your site at a click of a button
Made with: JavaScript
We will implement a dark theme selector for our site that visitors can activate by clicking on an icon. We will discuss what we have to do to the HTML, CSS and JavaScript files that make up our site to make that happen.
<!--DOCTYPE-->
<html>
<head>
<script src="script.js"></script>
<script
src="https://kit.fontawesome.com/3fe16e504a.js"
crossorigin="anonymous">
</script>
<link rel="stylesheet" href="style.css">
<title>Dark Theme</title>
</head>
<body>
<p>
<a href="contact.html">Contact</a> |
<a href="about.html">About</a>
<span id="toggle-switch" title="Toggle Dark Theme">
<i class="fas fa-moon" id="toggle-switch"></i>
</span>
</p>
<h1>My Dark Mode Theme</h1>
<p>This is a sample site to demo how to switch to dark mode.</p>
</body>
</html>
For this example, we will create three simple HTML pages: index.html
, about.html
and contact.html
. The code above is the index.html
page. At the top of each page, we will include a simple navigation menu next to which we will place a moon-shaped icon that users can click to turn on dark mode. Once in dark mode, the moon icon will switch to a sun icon, indicating that by clicking it the visitor can go back to the default light mode. Both the moon and the sun icons can be found in Fontawesome.
html {
--bck-color: #FFF;
--ft-color: #000;
--link-color: blue;
}
html.dark {
--bck-color: #000;
--ft-color: #FFF;
--link-color: #DDD;
}
body {
background: var(--bck-color);
color: var(--ft-color);
max-width: 40em;
padding: 5% 3%;
margin: 0 auto;
}
a:link,
a:visited,
a:active {
color: var(--link-color);
}
We will define some variables for the colors we want to use in our dark and light themes. To keep it simple, we will just focus on the background, the font and the link colors. We will define our variables in the html
element and we’ll then reference them in the body
and link
elements. We will also create a dark
class for the html
element that we will activate via JavaScript once a visitor clicks on the moon icon.
const DARK_MODE = 'dark';
const LIGHT_MODE = 'light';
const THEME = 'mode';
document.addEventListener(
'DOMContentLoaded', (event) => {
applyTheme();
const toggleSwitch = document.getElementById('toggle-switch');
toggleSwitch.onclick = function() {
let currentMode = localStorage.getItem(THEME);
localStorage.setItem(
THEME,
currentMode === DARK_MODE ? LIGHT_MODE : DARK_MODE
);
applyTheme();
}
}
);
function applyTheme() {
let html = document.documentElement;
let currentMode = localStorage.getItem(THEME);
if (currentMode === DARK_MODE) {
html.classList.add(DARK_MODE);
document.getElementById('toggle-switch').innerHTML =
'<i class="fas fa-sun"></i>';
}
else {
html.classList.remove(DARK_MODE);
document.getElementById('toggle-switch').innerHTML =
'<i class="fas fa-moon"></i>';
}
}
Here’s where the real magic happens. Since ours is a static site, we can’t rely on the server to store our mode preferences. We need to do it in the visitor’s browser, and for that we will make use of the localStorage
DOM property.
Since the default mode is light, you’ll get the site in light mode on your first visit. As soon as the page loads, an event listener on the DOMContentLoaded
event triggers a callback function that checks the browser’s localStorage
property for any record of the site’s mode. In our first visit there will be nothing stored there so the page will load in light mode.
Upon clicking in the moon icon, the value of the THEME
const will change to dark
and the key value pair will be stored in localStorage
via the localStorage.setItem(THEME, ...)
method. At the same time, the class of our html
element will be set to dark
and the innerHTML
of the span
containing the moon icon html code will change to display a sun icon instead. Clicking on the sun icon will take the visitor back to light mode by following the same process. The changes between light and dark mode are implemented via the applyTheme()
function.
Since the values stored in localStorage
are presistent, as long as the visitor uses the same browser it will remember the chosen mode next time the site is visited. You can test this by navigating to the different pages of the site, or even closing and opening your browser. Here is a demo where you can see this dark mode implementation in action.
© 2025 Mario Sanchez Carrion