Let's Implement Glassmorphism with CSS!
Learn How To Create a Frosted Glass Effect.
Hello friend, need that winter frosted glass effect? ๐ฅถ
It's called Glassmorphism. It is a design style coined by Michal Malewicz to connect and combine all the uses of the "frosted glass" effect in the user interface (UI). Thanks to the improved support for the backdrop-filter across desktop browsers, we can now create that cold winter night glass effect and enhance your UI experience!
So let's start by making a personal card with Glassmorphism using HTML & CSS step by step.
Take a good look at the preview above before we start coding the project . We will code the HTML first then the CSS comes next. I have shared the code snippets below to make it easier for you.
HTML ๐( step 1)
<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> Frosted Glass </title>
<link rel="stylesheet" href="./style.css">
<link rel="icon"
href="">
</head>
<body>
<div class="glass">
<a href="https://github.com/Mobey-eth">
<img src="./Your-image.jpg" alt="Your picture">
</a>
<p class="name"> Your Name </p>
<p class="text"> A beginner-friendly tutorial on Glassmorphism.
Follow for more cool Frontend, Javascript and Web3 stuff!
</p>
<button>
<a href="twitter.com/0xmobi">follow</a>
</button>
</div>
</body>
In the HTML, we used div tags for the container, we then proceed to design the card with CSS.
CSS๐( step - 2)
We address the background in the body tag and we set the height. This is essential to centering the "glass" class using flex.
body {
background-image: url("https://images.unsplash.com/photo-1519681393784-d120267933ba?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1124&q=100"); background-position: center;
background-repeat: no-repeat;
background-size: cover;
height: 100vh;
display: flex;
align-items: center;
justify-content: center;
}
Next, we set the display and specify the dimensions of the card on the "glass" class. I also like to add the "z-index" to give the card some sort of popping effect.
.glass {
display: block;
width: 30rem;
height: 24rem;
border-radius: 1rem;
z-index: 500;
}
Then for the secret sauce, we set the background color of the "glass" class and we add the "backdrop-filter", its optional to add a semi transparent border but it helps to highlight the edges.
.glass {
background: rgba(12, 30, 45, 0.7);
backdrop-filter: blur(0.7rem) saturate(180%);
box-shadow: 0.05rem 0.1rem 0.3rem rgba(255, 255, 255, 0.2);
border: 0.1rem solid rgba(255, 255, 255, 0.2);
}
You can also use the "white frosting glass effect" if you will, just adjust the background of the "glass" class to background: rgba(255, 255, 255, 0.6);
and voilร !
All that's left is to style the elements in the card to your satisfaction ๐. Remember there are no limits, go out there and do really creative stuff with this cool frosted glass effect you just learned!
Here is the rest of the CSS to make it even easier for you. ๐
@import url("https://fonts.googleapis.com/css2?family=Lato:wght@100;300&family=Poppins:wght@200;500;600;700&display=swap");
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
:root {
--color-one: rgba(12, 30, 45, 0.7);
--color-two: #aa3333;
}
html {
font-size: 62.5%;
font-family: "Lato", sans-serif;
font-family: "Poppins", sans-serif;
}
body {
background-image: url("https://images.unsplash.com/photo-1519681393784-d120267933ba?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1124&q=100");
background-position: center;
background-repeat: no-repeat;
background-size: cover;
height: 100vh;
display: flex;
align-items: center;
justify-content: center;
}
.glass {
display: block;
width: 30rem;
height: 24rem;
background: var(--color-one);
border-radius: 1rem;
z-index: 500;
-webkit-backdrop-filter: blur(0.7rem) saturate(180%);
backdrop-filter: blur(0.7rem) saturate(180%);
box-shadow: 0.05rem 0.1rem 0.3rem rgba(255, 255, 255, 0.2);
border: 0.1rem solid rgba(255, 255, 255, 0.2);
text-align: center;
color: #f2f2f2;
}
.glass .name {
font-family: poppins, sans-serif;
font-weight: bold;
font-size: 1.25rem;
margin: 0.8em;
color: rgba(242, 242, 242, 0.8);
letter-spacing: 0.5px;
}
.glass .text {
font-family: "Lato", sans-serif;
color: rgba(242, 242, 242, 0.631372549);
padding: 0 1.6rem;
}
.glass button {
margin: 1.1rem;
padding: 0.3rem 1.7rem;
background-color: #0437a3;
border: 0.1rem solid #0437a3;
border-radius: 0.5rem;
}
.glass button a {
font-family: lato, sans-serif;
text-decoration: none;
font-size: 1.1rem;
color: rgba(242, 242, 242, 0.8784313725);
}
.glass button:hover {
cursor: pointer;
background-color: rgb(209, 177, 134);
color: white;
font-weight: bold;
}
img {
height: 6.5rem;
width: 6.5rem;
border-radius: 50%;
margin-top: 3rem;
border: 1px rgba(242, 242, 242, 0.5607843137);
border-style: groove;
}
CONCLUSION
Now we have done the CSS coding, If you want to see a more robust example where I used the glass effect to make a user dashboard click the link below.
Got some questions or suggestions? don't hesitate to leave them in the comments section. Kindly follow and have fun!