A simple set of Sass (SCSS) examples demonstrating core concepts, along with corresponding HTML for visualization.
1. Variables
variables.scss
(Sass file)
$primary-color: #3498db;$secondary-color: #2ecc71;$font-size: 16px;
styles.scss
@import "variables";
.button {
background-color: $primary-color;
color: #fff;
font-size: $font-size;
padding: 10px 20px;
border: none;
border-radius: 5px;
&:hover {
background-color: $secondary-color;
}
}
Compile sass code to generate styles.css file
index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Try 1 Sass </title>
<link rel="stylesheet" href="styles.css">
</head>
<body>
Check this button <button class="button">Click Me</button>
</body>
</html>
Output
2. Nesting
nesting.scss
(Sass file)
.navbar {
background-color: #daf50a;
color: white;
display: flex;
align-items: center;
justify-content: space-between;
padding: 10px;
font-family: 'Franklin Gothic Medium', 'Arial Narrow', Arial, sans-serif;
font-size: 36px;
ul {
list-style: none;
padding: 0;
li {
display: inline;
margin-right: 15px;
a {
color: rgb(10, 10, 9);
text-decoration: none;
&:hover {
color: #e40b28;
}
}
}
}
}
styles.scss
@import "nesting";
Compile styles.scss to generate styles.css
nesting.html
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Nesting</title> <link rel="stylesheet" href="styles.css"></head><body> <div class="navbar"> <ul> <li><a href="#">Home</a></li> <li><a href="#">About</a></li> <li><a href="#">Contact</a></li> </ul> </div> </body></html>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Nesting</title>
<link rel="stylesheet" href="styles.css">
</head>
<body>
<div class="navbar">
<ul>
<li><a href="#">Home</a></li>
<li><a href="#">About</a></li>
<li><a href="#">Contact</a></li>
</ul>
</div>
</body>
</html>
output
button.scss
.button {background-color: $secondary-color;color: rgb(18, 170, 240);padding: 10px 20px;border: rgb(0, 255, 98) solid;border-radius: 15px;font-family: $font-family;font-size: medium;&:hover {background-color: white;}}
styles.scss
@import 'variables';@import 'nesting';@import 'buttons';
body { font-family: $font-family; margin: 0; padding: 0; background-color: $primary-color;}
.container { max-width: 400px; max-height: 200px; margin: 0px auto; text-align: left;}
@import 'variables';
@import 'nesting';
@import 'buttons';
body {
font-family: $font-family;
margin: 0;
padding: 0;
background-color: $primary-color;
}
.container {
max-width: 400px;
max-height: 200px;
margin: 0px auto;
text-align: left;
}
HTML
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Sass @import Example</title> <link rel="stylesheet" href="styles.css"></head><body> <nav class="navbar"> <ul> <li><a href="#">Home</a></li> <li><a href="#">About</a></li> <li><a href="#">Contact</a></li> </ul> </nav> <div class="container"> <h1>Welcome to Sass @import Example</h1> <button class="button">Click Me</button> </div></body></html>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Sass @import Example</title>
<link rel="stylesheet" href="styles.css">
</head>
<body>
<nav class="navbar">
<ul>
<li><a href="#">Home</a></li>
<li><a href="#">About</a></li>
<li><a href="#">Contact</a></li>
</ul>
</nav>
<div class="container">
<h1>Welcome to Sass @import Example</h1>
<button class="button">Click Me</button>
</div>
</body>
</html>
Compile styles.scss to generate styles.css file
Check the outpit
4. Partials
Partials are partial SCSS files (e.g.,
_variables.scss
) that don’t generate CSS. Use@import
to include them.
_variables.scss
$primary-color: #e74c3c;
$secondary-color: #2ecc71;
_mixins.scss
@mixin center {
display: flex;
justify-content: center;
align-items: center;
}
main.scss
@import 'variables';
@import 'mixins';
.container {
height: 100vh;
background-color: $primary-color;
@include center {
color: white;
font-size: 24px;
}
}
HTML
<div class="container">Centered Content</div>
5. Mixins
_mixins.scss
@mixin button-style($bg-color, $text-color: rgb(14, 1, 1), $radius: 5px) { background-color: $bg-color; color: $text-color; border: none; border-radius: $radius; padding: 10px 20px; font-size: 16px; text-transform: uppercase; cursor: pointer; &:hover { background-color: lighten($bg-color, 30%); } } @mixin flex-center { display: flex; justify-content: space-evenly; align-items: center; }
_variables.scss
$primary-color: #4ae73c;
$secondary-color: #312ecc;
_main.scss
@import 'mixins';
body {
font-family: Arial, sans-serif;
margin: 0;
padding: 0;
}
.header {
height: 10vh;
background-color: #3498db;
color: white;
@include flex-center;
h1 {
font-size: 3rem;
}
}
.button-primary {
@include button-style(#2ecc71, white, 10px);
}
.button-secondary {
@include button-style(#6f3ce7, white, 20px);
}
HTML
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Sass Mixins Example</title> <link rel="stylesheet" href="main.css"></head><body> <header class="header"> <h1>Welcome to Mixins Example</h1> </header> <div style="text-align: center; margin-top: 20px;"> <button class="button-primary">Primary Button</button> <button class="button-secondary">Secondary Button</button> </div></body></html>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Sass Mixins Example</title>
<link rel="stylesheet" href="main.css">
</head>
<body>
<header class="header">
<h1>Welcome to Mixins Example</h1>
</header>
<div style="text-align: center; margin-top: 20px;">
<button class="button-primary">Primary Button</button>
<button class="button-secondary">Secondary Button</button>
</div>
</body>
</html>
output
6. Extends
_extends.scss
%btn { display: inline-block; padding: 10px 20px; text-align: center; border-radius: 5px; color: white; } .button-primary { @extend %btn; background-color: $primary-color; } .button-secondary { @extend %btn; background-color: $secondary-color; }
styles.scss
@import 'variables';@import 'extends';
HTML
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Sass Extends Demo</title><link rel="stylesheet" href="styles.css"></head><body><a href="#" class="button-primary">Primary</a><a href="#" class="button-secondary">Secondary</a></body></html>
output
7. Operators
_operators.scss
$base-size: 16px;
.container { font-size: $base-size * 1.5; // 24px padding: $base-size / 2; // 8px}
styles.scss
@import 'operators';
HTML
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Sass Operators </title>
<link rel="stylesheet" href="styles.css">
</head>
<body>
<div class="container">Responsive Container</div>
</body>
output
8. Interpolation
Variable Interpolation is a SASS feature that developers can use to dynamically inject the value of a variable into selectors and properties. It can be done by utilizing the '#{}' syntax. Developers can create dynamic stylesheets by using static text with variable values via variable interpolation.
_interpolation.scss
$breakpoints: (small: 50px, medium: 100px, large: 150px);
@each $name, $size in $breakpoints { .container-#{$name} { height: $size; width: $size; background-color: lime; padding: 20px; }}
styles.scss
@import 'interpolations';
HTML
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Sass Interpolation Demo</title>
<link rel="stylesheet" href="styles.css">
</head>
<body>
<div class="container-small">Small</div>
<div class="container-medium">Medium</div>
<div class="container-large">Large</div>
</body>
</html>
output
9. Directives
_directives.scss
$primary-color: #3498db;
@if $primary-color == #3498db { .info { background-color: $primary-color; color: rgb(230, 238, 231); height: 20px; } } @else { .info { background-color: grey; color: black; height: 20px; } }
styles.scss
@import 'directives';
HTML
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Sass Directive Demo</title>
<link rel="stylesheet" href="styles.css">
</head>
<body>
<div class="info">Conditional Styling</div>
</body>
</html>
output
Profile Awesome web site Project
styles.scss
* {
padding: 0;
margin: 0;
box-sizing: border-box;
}
body {
background-image: linear-gradient(rgb(162, 240, 72), rgb(247, 247, 238));
}
nav {
display: flex;
justify-content: space-around;
align-items: center;
margin-top: 2rem;
.icons i {
margin-left: 20px;
font-size: 20px;
cursor: pointer;
}
ul li {
display: inline;
margin-left: 20px;
list-style: none;
a {
text-decoration: none;
//text-decoration: underline solid;
font-family: sans-serif;
color: #181818;
}
}
}
main {
display: flex;
justify-content: space-around;
align-items: center;
flex-wrap: wrap;
margin: 6rem;
background-image: linear-gradient(rgb(162, 240, 72), rgb(247, 247, 238));
}
.image-container {
background: #fff;
border-radius: 200px;
padding: 20px;
box-shadow: 4px 4px 10px -4px #ccc;
.image {
background: url(rmc.jpg);
background-repeat: no-repeat;
background-size: cover;
background-position: center;
width: 300px;
height: 500px;
border-radius: 150px;
margin-top: 30spx;
}
}
.content {
margin: 3rem 0;
font-family: sans-serif;
.badge-label {
margin-bottom: 20px;
font-size: 1.4rem;
}
p.info {
width: 300px;
color: #4a4a4a;
line-height: 1.5;
}
}
.pills-container {
display: grid;
grid-template-columns: 100px 100px 100px;
gap: 10px;
.pill {
border: 2px solid white;
box-shadow: 4px 4px 10px -4px #ccc;
padding: 10px 20px;
border-radius: 100px;
width: 100px;
text-align: center;
}
}
.content2 {
text-align: right;
.info {
transform: translateX(20px);
}
}
index.html (Thanks to HUXN Web Dev)
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Awesome Header</title>
<link rel="stylesheet" href="style.css" />
<!-- Font Awesome -->
<link
rel="stylesheet"
href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.3.0/css/all.min.css"
integrity="sha512-SzlrxWUlpfuzQ+pcUCosxcglQRNAq/DZjVsC0lE40xsADsfeQoEypE+enwcOiGjk/bSuGGKHEyjSoQ1zVisanQ=="
crossorigin="anonymous"
referrerpolicy="no-referrer"
/>
</head>
<body>
<nav>
<div class="icons">
<i class="fa-brands fa-youtube"></i>
<i class="fa-brands fa-twitter"></i>
<i class="fa-brands fa-github"></i>
<i class="fa-brands fa-instagram"></i>
</div>
<ul>
<li><a href="#">HOME</a></li>
<li><a href="#">WORK</a></li>
<li><a href="#">CONTACT</a></li>
</ul>
</nav>
<main>
<div class="content1">
<div class="content">
<p class="badge-label">BADGE</p>
<p class="info">I'm a Life Long Learner and UI/UX lover.</p>
</div>
<div class="content">
<p class="badge-label">TOOLS</p>
<p class="info">
I've worked with lots of popular & unpopular technologies,
frameworks, and libraries.
</p>
</div>
<div class="content">
<p class="badge-label">Languages</p>
<div class="pills-container">
<p class="pill">JS</p>
<p class="pill">C</p>
<p class="pill">Python</p>
<p class="pill">Java</p>
<p class="pill">Dart</p>
<p class="pill">C++</p>
</div>
</div>
</div>
<div class="image-container">
<div class="image"></div>
</div>
<div class="content2">
<div class="content">
<p class="badge-label">Previous Work</p>
<p class="info">Previously I've worked with Aurele, Tata NELCO, Anna, Annamalai Universities & Etiacm Inc, CA, USA</p>
</div>
<div class="content">
<p class="badge-label">Hobbies</p>
<div class="pills-container">
<p class="pill">Teaching</p>
<p class="pill">Learning</p>
<p class="pill">Reading</p>
<p class="pill">Writing</p>
<p class="pill">Coding</p>
</div>
</div>
<div class="content">
<p class="badge-label">Location</p>
<p class="info">Annamalai Nagar</p>
</div>
</div>
</main>
</body>
</html>
output
Final Notes:
- Save each
.scss
file as separate files if using imports and partials. - Compile the SCSS files into a single
.css
file using a tool likesass
CLI or online compilers. - Link the resulting
.css
file in your HTML.