Theming in SASS: CSS variables
Tech

Theming in SASS: CSS variables

Kaushik
February 15, 2024
2
mins

Sass is a CSS preprocessor and an extension to CSS. So whatever we define in the Sass file, on the browser level gets converted to CSS.

After doing my research I found that if any product has a requirement of theming the developer should go with CSS, not Sass. With Sass, they are some disadvantages which I will discuss later.

Theming in Sass works similar to CSS:- First, we need to define the CSS variables in the (: root)

:root {

- -background: #FFA69E;

- -text-color: #0F0F0F;

}

So here root is a pseudo-class that selects the document’s root element. A pseudo-class is used to define a special state of an element. So these variables must be defined at your app's top level. Once we define these variables we can use these CSS variables in Sass files or different Sass variables with the help of var() function which is used to insert the value of a CSS variables. eg:

body { background-color: var(- -background); }

$xyz : var(- -text-color );

Through this, we can achieve theming in Sass, but there is a disadvantage with Sass:
— Sass has mixin functions like lighten(color, x%) and darken(color, x%), so these mixins don’t accept CSS variables, these mixins need exact hex code to work.
— So if you are using bootstrap Sass from the library then you need to make the whole bootstrap Sass file committable and find an alternative to the mixin functions (lighten and darken).

Once we define and set the CSS variables we can change the value of these CSS variables through DOM manipulation eg-:

document.documentElement.style.setProperty(‘- -blue’, ‘#89CFF0’);

On the button click, I am doing DOM manipulation and changing the background color. Anyway, DOM manipulation is an expensive process. If your application is very big or very dynamic, the time spent manipulating DOM elements rapidly adds up and you may have performance issues in your app.

Alternative to this we can write our own mixin functions and we can add themes to the app.

Here is the link to the blog:- Theming with Sass: An SCSS Tutorial

But if an app is already big then writing your own mixin function will be pretty tedious work because you need to call the mixin function from every file.

Happy learning :)is

See our award-winning HR Software in action
Book a demo
Schedule a demo
Is accurate payroll processing a challenge? Find out how peopleHum can assist you!
Book a demo
Book a demo
See our award-winning HR Software in action
Schedule a demo

See our award-winning HR Software in action

Schedule a demo
Blogs related to "
Theming in SASS: CSS variables
"

Schedule a Demo !

Get a personalized demo with our experts to get you started
This is some text inside of a div block.
This is some text inside of a div block.
This is some text inside of a div block.
This is some text
This is some text inside of a div block.
Thank you for scheduling a demo with us! Please check your email inbox for further details.
Explore payroll
Oops! Something went wrong while submitting the form.
Contact Us!
Get a personalized demo with our experts to get you started
This is some text inside of a div block.
This is some text inside of a div block.
This is some text inside of a div block.
This is some text inside of a div block.
Thank you! Your submission has been received!
Oops! Something went wrong while submitting the form.