« Адаптивное меню navbar с использованием CSS, HTML и JS »

Описание материала:
Хотите узнать больше об адаптивных опциях navbar css? Больше ни слова. Панель навигации, которая не только сжимается или расширяется в зависимости от размера экрана вашего устройства, но и полностью меняет свое поведение. Как вы видели на демонстративной странице, вы получаете обычное горизонтальное меню, а проверка его с мобильного устройства приводит к переключателю, который состоит из меню в вертикальном выравнивании благодаря CSS. Таким образом, одно меню для всего устройства - это то, что вы получаете отсюда.
Установка:
HTML код:
Код
<div class="navbar">
<div class="logo">
<h2>UFIVE.RU</h2>
</div>
<ul class="links">
<li><a href="#">Главная</a></li>
<li><a href="#">Форум</a></li>
<li><a href="#">Материалы</a></li>
<li><a href="#">Контакты</a></li>
</ul>
<div class="right"><button>Поддержка</button></div>
<div class="toggle">
<div class="line1"></div>
<div class="line2"></div>
<div class="line3"></div>
</div>
</div>
<div class="logo">
<h2>UFIVE.RU</h2>
</div>
<ul class="links">
<li><a href="#">Главная</a></li>
<li><a href="#">Форум</a></li>
<li><a href="#">Материалы</a></li>
<li><a href="#">Контакты</a></li>
</ul>
<div class="right"><button>Поддержка</button></div>
<div class="toggle">
<div class="line1"></div>
<div class="line2"></div>
<div class="line3"></div>
</div>
</div>
CSS код:
Код
@import url("https://fonts.googleapis.com/css?family=Lacquer|Nunito&display=swap");
@import url("https://fonts.googleapis.com/css?family=Nunito&display=swap");
* {
box-sizing: border-box;
transition: 0.4s ease all;
}
h1,
h2,
h3,
h4,
h5,
h6 {
margin: 0;
}
ul {
padding: 0;
margin: 0;
}
.navbar {
background: #080808;
color: #fff;
padding: 15px;
width: 100%;
height: 65px;
display: flex;
align-items: center;
}
.navbar .logo {
cursor: pointer;
font-family: "Lacquer";
}
.navbar ul.links {
font-family: "Nunito";
margin-left: auto;
margin-right: 50px;
list-style: none;
display: flex;
align-items: center;
transition: 0.4s ease all, 0s ease background;
}
.navbar ul.links li {
text-transform: uppercase;
padding: 0 15px;
height: 65px;
display: flex;
justify-content: center;
align-items: center;
transition: 0.4s ease all, 0s ease margin;
}
.navbar ul.links li a {
text-decoration: none;
color: #fff;
}
.navbar ul.links li:hover {
background: #ffc600;
cursor: pointer;
}
.navbar ul.links li:hover a {
color: #080808;
}
button {
background: #ffc600;
outline: none;
font-weight: bold;
padding: 10px 18px;
border-radius: 25px;
border: 1px solid #e6b200;
letter-spacing: 1px;
}
button:hover {
cursor: pointer;
transform: scale(1.1);
color: white;
background: #222;
border-color: #000;
}
.content {
background-size: cover;
height: calc(100vh - 65px);
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
color: #fff;
}
.content h2 {
color: #ffc600;
}
.navbar.sticky {
position: fixed;
z-index: 40;
}
.navbar.sticky ~ main {
position: relative;
z-index: 20;
top: 65px;
}
section {
background: #000;
color: #ffc600;
padding: 20px;
font-family: "Lacquer";
font-weight: bold;
letter-spacing: 0.5px;
}
@media screen and (max-width: 850px) {
.navbar .right {
height: 0;
overflow: hidden;
}
.toggle {
position: absolute;
top: 32.5px;
right: 20px;
z-index: 99;
transform: translateY(-50%);
cursor: pointer;
width: 40px;
height: 40px;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
.toggle > * {
width: 80%;
height: 2px;
background: #fff;
margin: 3px 0;
}
.navbar.collapsed .toggle .line1 {
transform: rotate(-45deg) translate(-4px, 5px);
}
.navbar.collapsed .toggle .line2 {
opacity: 0;
}
.navbar.collapsed .toggle .line3 {
transform: rotate(45deg) translate(-5px, -6px);
}
.navbar.collapsed .logo {
position: absolute;
z-index: 44;
}
.navbar .links {
position: fixed;
background: #080808;
font-family: "Nunito";
z-index: 40;
top: 0;
left: -100%;
flex-direction: column;
width: 45vw;
height: 100vh;
}
.navbar .links li:first-child {
margin-top: 80px;
}
.navbar.collapsed .links {
left: 0;
}
.navbar.collapsed .links a {
color: #fff;
}
.navbar.collapsed .links li {
width: 100%;
}
.navbar.collapsed .links li:hover a {
color: #080808;
}
.navbar.collapsed .right {
position: fixed;
font-family: "Nunito";
width: 45vw;
text-align: center;
height: auto;
bottom: 40px;
left: 22.5vw;
transform: translateX(-50%);
z-index: 45;
}
.navbar.collapsed ~ main {
filter: blur(1px);
opacity: 0.8;
}
.navbar.sticky {
position: fixed;
z-index: 40;
}
}
@import url("https://fonts.googleapis.com/css?family=Nunito&display=swap");
* {
box-sizing: border-box;
transition: 0.4s ease all;
}
h1,
h2,
h3,
h4,
h5,
h6 {
margin: 0;
}
ul {
padding: 0;
margin: 0;
}
.navbar {
background: #080808;
color: #fff;
padding: 15px;
width: 100%;
height: 65px;
display: flex;
align-items: center;
}
.navbar .logo {
cursor: pointer;
font-family: "Lacquer";
}
.navbar ul.links {
font-family: "Nunito";
margin-left: auto;
margin-right: 50px;
list-style: none;
display: flex;
align-items: center;
transition: 0.4s ease all, 0s ease background;
}
.navbar ul.links li {
text-transform: uppercase;
padding: 0 15px;
height: 65px;
display: flex;
justify-content: center;
align-items: center;
transition: 0.4s ease all, 0s ease margin;
}
.navbar ul.links li a {
text-decoration: none;
color: #fff;
}
.navbar ul.links li:hover {
background: #ffc600;
cursor: pointer;
}
.navbar ul.links li:hover a {
color: #080808;
}
button {
background: #ffc600;
outline: none;
font-weight: bold;
padding: 10px 18px;
border-radius: 25px;
border: 1px solid #e6b200;
letter-spacing: 1px;
}
button:hover {
cursor: pointer;
transform: scale(1.1);
color: white;
background: #222;
border-color: #000;
}
.content {
background-size: cover;
height: calc(100vh - 65px);
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
color: #fff;
}
.content h2 {
color: #ffc600;
}
.navbar.sticky {
position: fixed;
z-index: 40;
}
.navbar.sticky ~ main {
position: relative;
z-index: 20;
top: 65px;
}
section {
background: #000;
color: #ffc600;
padding: 20px;
font-family: "Lacquer";
font-weight: bold;
letter-spacing: 0.5px;
}
@media screen and (max-width: 850px) {
.navbar .right {
height: 0;
overflow: hidden;
}
.toggle {
position: absolute;
top: 32.5px;
right: 20px;
z-index: 99;
transform: translateY(-50%);
cursor: pointer;
width: 40px;
height: 40px;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
.toggle > * {
width: 80%;
height: 2px;
background: #fff;
margin: 3px 0;
}
.navbar.collapsed .toggle .line1 {
transform: rotate(-45deg) translate(-4px, 5px);
}
.navbar.collapsed .toggle .line2 {
opacity: 0;
}
.navbar.collapsed .toggle .line3 {
transform: rotate(45deg) translate(-5px, -6px);
}
.navbar.collapsed .logo {
position: absolute;
z-index: 44;
}
.navbar .links {
position: fixed;
background: #080808;
font-family: "Nunito";
z-index: 40;
top: 0;
left: -100%;
flex-direction: column;
width: 45vw;
height: 100vh;
}
.navbar .links li:first-child {
margin-top: 80px;
}
.navbar.collapsed .links {
left: 0;
}
.navbar.collapsed .links a {
color: #fff;
}
.navbar.collapsed .links li {
width: 100%;
}
.navbar.collapsed .links li:hover a {
color: #080808;
}
.navbar.collapsed .right {
position: fixed;
font-family: "Nunito";
width: 45vw;
text-align: center;
height: auto;
bottom: 40px;
left: 22.5vw;
transform: translateX(-50%);
z-index: 45;
}
.navbar.collapsed ~ main {
filter: blur(1px);
opacity: 0.8;
}
.navbar.sticky {
position: fixed;
z-index: 40;
}
}
JS код:
Код
const navbar = document.querySelector(".navbar");
navbar.querySelector(".toggle").addEventListener("click", () => {
navbar.classList.toggle("collapsed");
});
window.addEventListener("scroll", e => {
let windowY = window.pageYOffset;
let navbarHeight = document.querySelector(".navbar").offsetHeight;
if (windowY > navbarHeight) navbar.classList.add("sticky");
else navbar.classList.remove("sticky");
});
navbar.querySelector(".toggle").addEventListener("click", () => {
navbar.classList.toggle("collapsed");
});
window.addEventListener("scroll", e => {
let windowY = window.pageYOffset;
let navbarHeight = document.querySelector(".navbar").offsetHeight;
if (windowY > navbarHeight) navbar.classList.add("sticky");
else navbar.classList.remove("sticky");
});
Демонстрация
Демонстративная страница или сайт материала
Установка материалаМы поможем установить данный материал к Вам на сайт
Добавил: YaVi | Категория: Меню и навигация | Просмотров: 1272
Теги к материалу: css, navbar, Адаптивное меню, html, JavaScript, js, с использованием
Поделиться в соц. сетях:
К данному материалу нет комментариев, но Вы можете стать первым, оставив свой комментарий!
Комментариев: 0
| |