This content originally appeared on DEV Community and was authored by Pasindu Codes
Welcome back, guys. ✌ In this article you will be learning how to create this beautiful navigation bar with HTML, CSS, and a little bit of JavaScript. This is a quick preview of what we are going to create today. 👇
It is very easy and simple to understand. So let's make this 😉. I have discussed step by step how to create this and at the end, there is a complete code also.
HTML CODE
<nav>
<ul>
<li>
<span data-color="#3f3f64">
<img src="./images/service-icon.png" alt="service-icon" />
<img
class="color-image"
src="./images/service-icon-color.png"
alt="service-icon"
/>
</span>
</li>
<li>
<span data-color="#794343">
<img src="./images/support-icon.png" alt="support-icon" />
<img
class="color-image"
src="./images/support-icon-color.png"
alt="support-icon"
/>
</span>
</li>
<li>
<span data-color="#8be8ff">
<img src="./images/home-icon.png" alt="home-icon" />
<img
class="color-image"
src="./images/home-icon-color.png"
alt="home-icon"
/>
</span>
</li>
<li>
<span data-color="#f7a11fa2">
<img src="./images/stats-icon.png" alt="stats-icon" />
<img
class="color-image"
src="./images/stats-icon-color.png"
alt="stats-icon"
/>
</span>
</li>
<li>
<span data-color="#b33136">
<img src="./images/feedback-icon.png" alt="feedback-icon" />
<img
class="color-image"
src="./images/feedback-icon-color.png"
alt="feedback-icon"
/>
</span>
</li>
</ul>
</nav>
So as this is a navigation bar I decided to use the <nav>
element to create this. Everything is inside the <nav>
tag, and there is an unordered list in it to create the links.
CSS for Nav Bar
nav {
width: 50%;
}
nav ul {
list-style-type: none;
overflow: hidden;
display: flex;
align-items: center;
justify-content: space-around;
background-color: #8395a7;
border-radius: 10px;
}
Created a flex box and justify-content: space-around
to create equal spaces between images. list-style-type: none
to remove the bullets and overflow: hidden
to avoind overflowing the content. set a bacground-color
and border-radius
to look better. 😏
<li> Tag
<span data-color="#3f3f64">
<img src="./images/service-icon.png" alt="service-icon" />
<img
class="color-image"
src="./images/service-icon-color.png"
alt="service-icon"
/>
</span>
The images are created inside the <span>
tag. And you can see there are two images inside the<span>
tag. One is the black and white and the other is color image. the data-color
attribute in the<span>
tag is made for the function of JavaScript. You can see it at the end of this article.
nav ul li span {
display: block;
padding: 15px 0;
cursor: pointer;
position: relative;
}
These are the stylings for <span>
tag. display: block
unless we can't change the padding values because it is a inline element by default. position: relative
because the colored image is going to be absolute to that element.
img {
width: 70px;
}
Set an fixed width
to the image.
The most important part is positioning the colored image. I position the colored image right in front of the black and white image. So that the black and white image is under the colored image. Then I set the colored image'sopacity: 0
so that the colored image cannot be seen. But still, the colored image is in front of the black and white image. So the hover effect is to bring back the opacity with a transition. And it will be like an animation of color-changing 😁.
.color-image {
position: absolute;
left: 0;
opacity: 0;
transition: all 0.25s;
}
.color-image:hover {
opacity: 1;
}
👍 So here is the complete CSS code for the project.
* {
box-sizing: border-box;
padding: 0;
margin: 0;
}
body {
width: 100%;
height: 100vh;
display: flex;
align-items: center;
justify-content: center;
transition: all 1s;
background-color: #3f3f64;
}
nav {
width: 50%;
}
nav ul {
list-style-type: none;
overflow: hidden;
display: flex;
align-items: center;
justify-content: space-around;
background-color: #8395a7;
border-radius: 10px;
}
nav ul li span {
display: block;
padding: 15px 0;
cursor: pointer;
position: relative;
}
img {
width: 70px;
}
.color-image {
position: absolute;
left: 0;
opacity: 0;
transition: all 0.25s;
}
.color-image:hover {
opacity: 1;
}
JAVASCRIPT
This is the JavaScript part. It is very simple. All it does is change the background-color
of the document when an icon is clicked. (Just for fun 😂). So here it is...
const link = document.querySelectorAll("span"); // Getting all the span elements
const body = document.querySelector("body"); // Getting the body
link.forEach((item) => {
item.addEventListener("click", () => {
const bodyColor = item.dataset.color;
body.style.backgroundColor = bodyColor;
});
});
So in here I have selected all the <span>
elements using querySelectorAll
and when a <span>
element is clicked, it takes the data-color
attribute of that element and set that color as the bacground-color
of the document.
🔗 LINKS
- Link to the Github Repository
- Follow me on Twitter
- Follow me on Instagram
- Download SVG icons from flaticon
Leave a like 👍 and share 🤙 this article to your friends so that they will also learn what you learned from this. Comment 💬 down you ideas about this. See you in the article. :)
This content originally appeared on DEV Community and was authored by Pasindu Codes
Pasindu Codes | Sciencx (2021-11-17T14:39:15+00:00) Icon Navigation Bar With Animated Hover Effects. Retrieved from https://www.scien.cx/2021/11/17/icon-navigation-bar-with-animated-hover-effects/
Please log in to upload a file.
There are no updates yet.
Click the Upload button above to add an update.