Как создать адаптивное меню панели навигации с индикатором в HTML CSS и JavaScript
В этом видео мы сделаем адаптивное меню навигационной панели с помощью HTML CSS и jаvascript. Надеюсь, это видео будет вам полезно. Вы можете скачать коды по ссылке, указанной ниже.
Вы можете посмотреть видео демонстрацию, попробовать сверстать самому по видео или скачать архив с готовым кодом. Если это видео оказалось для вас полезным, оставьте комментарий со своими мыслями или вопросами. Ваши отзывы помогают нам создавать более ценный контент.
В архиве находится:
- Все демонстрационные изображения
- Исходные файлы HTML
- Исходные файлы CSS
- Исходные файлы jаvascript
- Иконки шрифтов
- Файлы библиотеки и плагинов
HTML КОД:
<!DOCTYPE html>
<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>Responsive Navbar Menu</title>
<!--css file-->
<link rel="stylesheet" href="styles.css" />
</head>
<body>
<nav>
<ul>
<li><a href="#">MonsterTem.ru</a></li>
<li class="hide"><a href="#">Home</a></li>
<li class="hide"><a href="#">Products</a></li>
<li class="hide"><a href="#">Blog</a></li>
<li class="hide"><a href="#">About</a></li>
<li class="hide"><a href="#">Contact</a></li>
<li class="menu-btn" onclick="showSidebar()">
<a href="#"><img src="menu-btn.svg" alt="" /></a>
</li>
</ul>
<ul class="sidebar">
<li onclick="hideSidebar()">
<a href="#"><img src="close-btn.svg" alt="" /></a>
</li>
<li><a href="#">Home</a></li>
<li><a href="#">Products</a></li>
<li><a href="#">Blog</a></li>
<li><a href="#">About</a></li>
<li><a href="#">Contact</a></li>
</ul>
</nav>
<script src="app.js"></script>
</body>
</html>
CSS КОД:
/* Google Fonts(Poppins) */
@import url("https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");
* {
font-family: "Poppins", sans-serif;
list-style: none;
text-decoration: none;
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
min-height: 100vh;
background: url(bg.jpg);
background-size: cover;
background-position: center;
background-repeat: no-repeat;
}
nav {
background: #fff;
padding: 0 5%;
box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.1);
}
nav ul {
width: 100%;
display: flex;
align-items: center;
justify-content: flex-end;
}
nav ul li {
height: 60px;
list-style: none;
}
nav ul li a {
height: 100%;
padding: 0 20px;
display: flex;
align-items: center;
color: #222;
}
nav ul li a:hover {
background: #f0f0f0;
}
nav ul li:first-child {
margin-right: auto;
}
nav ul li:first-child a {
font-size: 20px;
font-weight: 600;
}
.menu-btn {
display: none;
}
nav img {
width: 25px;
height: 25px;
}
.sidebar {
display: none;
}
@media (max-width: 700px) {
.hide {
display: none;
}
.menu-btn {
display: block;
}
.sidebar {
position: fixed;
top: 0;
right: -100%;
height: 100vh;
width: 100%;
max-width: 250px;
background: rgba(255, 255, 255, 0.15);
backdrop-filter: blur(12px);
box-shadow: -10px 0 10px rgba(0, 0, 0, 0.1);
display: flex;
flex-direction: column;
align-items: flex-start;
justify-content: flex-start;
transition: 0.5s;
}
.sidebar li {
width: 100%;
}
.sidebar li a {
width: 100%;
}
}
jаvascript КОД:
function showSidebar() {
const sidebar = document.querySelector(".sidebar");
sidebar.style.right = "0";
}
function hideSidebar() {
const sidebar = document.querySelector(".sidebar");
sidebar.style.right = "-100%";
}