Digvijay Singh
Nov 06, 2022
6 min read
Copy link
Nowadays, while developing a website or web application, You need to take care of the theming of the website. You need to think about how easily theming can be manageable with minimum CSS.
So, for your help, we have CSS variables. CSS variables are custom properties, which can be defined once and reused a number of times.
body { --main-color: black; }
we will be building day and night mode theme switcher application using CSS variables and vanilla javascript, let’s get started
Always remember theming css should not mixed with other css, so keep it separately
body {
margin: 0;
padding: 0;
}
.dark {
--bgColor: #161625;
--color: white;
--headerBg: #161625;
}
.light {
--bgColor: white;
--color: black;
--headerBg: #E8E8E8;
}
We’ve created a simple configuration for dark theme and light theme where we defined background color, font color, and header background.
we have created a basic application where we just changing the color scheme for header, body background, and font color. For advanced you can manage the number of things.
Creating A User Interface
We’ve created a simple layout where we have header menus and some grids in the main body. In the header we have a theme toggle button which will be used for switching between light and dark theme.
We have enabled light theme by default as you can see in HTML above we have added light class in body
.header li {
display: inline-block;
list-style: none;
padding: 0 10px;
font-weight: bold;
font-size: larger;
cursor: pointer;
}
body {
background-color: var(--bgColor);
transition: ease-in 1s;
}
.header-container {
display: flex;
background-color: var(--headerBg);
color: var(--color);
height: 56px;
transition: ease-in 1s;
}
.logo-section .logo {
font-weight: bold;
font-size: x-large;
margin-left: 10px;
}
.header-contaieer .menu-section {
display: flex;
justify-content: flex-end;
align-items: center;
}
.header-container .logo-section, .header-container .menu-section
{
display: flex;
align-items: center;
flex-basis: 50%;
}
.main-container {
display: flex;
width:80%;
margin: 0 auto;
justify-content: space-between;
flex-wrap: wrap;
}
.main-container .grid{
flex-basis: 300px;
height: 300px;
box-sizing: border-box;
border: 1px solid #888;
border-radius: 5px;
padding: 5px;
margin: 10px;
color: var(--color);
}
.grid .img-section img {
width: 100%;
height: 200px;
}
As you can see we have used flex-box layout for designing a webpage and uses a CSS variable to the point so while switching between themes we don’t need to care about the CSS part.
Let’s write Business logic for handling switching functionality between themes:
Business Logic
const bodyContainer = document.body; const themeAction =
document.getElementById('theme-action');
const currentTheme = localStorage.getItem('theme');
if(currentTheme && currentTheme == 'dark'){
bodyContainer.classList.replace('light','dark');
localStorage.setItem('theme','dark');
themeAction.classList.replace('fa-moon-o','fa-sun-o');
}
themeAction.onclick = () =>{
if(bodyContainer.classList.contains('light')){
bodyContainer.classList.replace('light','dark');
localStorage.setItem('theme','dark');
themeAction.classList.replace('fa-moon-o','fa-sun-o');
} else if(bodyContainer.classList.contains('dark')){
bodyContainer.classList.replace('dark','light');
localStorage.setItem('theme','light');
themeAction.classList.replace('fa-sun-o','fa-moon-o');
}
}
As you can see, we have used local storage to maintain user preference because whenever the user comes back he should be on the same theme.
We have sun/moon icon at the top which is used for toggling between light and dark theme and we added click event on these icons and toggled the theme. During the onClick event we are setting user preference into the theme and changing to the light or dark theme as per user preferences.
And whenever the user comes the first time, we check is the user already set his preference or not then taken action appropriately. If the user preferred theme is light then no need to do any operation initial level because by default theme is light.
CSS variables are very useful when want to change things dynamically which can not be possible with preprocessors like sass, less
TechTalk
15
People Speak
15
USA - Headquarters
4000 Executive
Parkway, Suite 264
San Ramon, CA 94583
India - Hyderabad
4th Floor, Sy 41&42, Opp. Best Western
Jubilee Ridge, 17, Madhapur Rd, Kavuri Hills,
Hyderabad, Telangana 500033
Mail ID:
© Enterprise Minds