Как создать адаптивную панель навигации с переключением на Темный и Светлый режим
Сегодня вы узнаете как создать адаптивную панель навигации с Темным или Светлым режим используя HTML, CSS и jаvascript. Вы можете посмотреть видео демонстрацию, скопировать готовый код ниже, попробовать сверстать самому или скачать архив с готовым кодом. Если это видео оказалось для вас полезным, оставьте комментарий со своими мыслями или вопросами. Ваши отзывы помогают нам создавать более ценный контент.
Интересной особенностью этого меню является то, что выбранная тема не изменится, если мы обновим страницу или снова откроем файл, и вы можете закрыть боковую панель, щелкнув любую область веб-страницы. Добавлена панель поиска в эту панель навигации, и эта панель навигации полностью адаптивна и отзывчива.
Панель навигации — это горизонтальная часть, содержащая ссылки навигации по логотипу, расположенные в верхней части веб-страницы.
Основная цель этой панели навигации — облегчить пользователям перенаправление с одной веб-страницы на другую.
Интересно в этом меню панели навигации то, что выбранный пользователем режим не изменится при повторном открытии страницы с обновленным файлом. Существует множество строк меню навигации, но эта панель навигации имеет некоторые расширенные функции с красивым пользовательским интерфейсом и дизайном UX.
HTML КОД:
<!DOCTYPE html>
<!-- === Coding by CodingLab | www.codinglabweb.com === -->
<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">
<!-- ===== CSS ===== -->
<link rel="stylesheet" href="style.css">
<!-- ===== Boxicons CSS ===== -->
<link href='https://unpkg.com/boxicons@2.1.1/css/boxicons.min.css' rel='stylesheet'>
<title>Responsive Navigation Menu Bar</title>
</head>
<body>
<nav>
<div class="nav-bar">
<i class='bx bx-menu sidebarOpen' ></i>
<span class="logo navLogo"><a href="#">CodingLab</a></span>
<div class="menu">
<div class="logo-toggle">
<span class="logo"><a href="#">CodingLab</a></span>
<i class='bx bx-x siderbarClose'></i>
</div>
<ul class="nav-links">
<li><a href="#">Home</a></li>
<li><a href="#">About</a></li>
<li><a href="#">Portfolio</a></li>
<li><a href="#">Services</a></li>
<li><a href="#">Contact</a></li>
</ul>
</div>
<div class="darkLight-searchBox">
<div class="dark-light">
<i class='bx bx-moon moon'></i>
<i class='bx bx-sun sun'></i>
</div>
<div class="searchBox">
<div class="searchToggle">
<i class='bx bx-x cancel'></i>
<i class='bx bx-search search'></i>
</div>
<div class="search-field">
<input type="text" placeholder="Search...">
<i class='bx bx-search'></i>
</div>
</div>
</div>
</div>
</nav>
<script src="script.js"></script>
</body>
</html>
CSS КОД:
/* ===== Google Font Import - Poppins ===== */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600&display=swap');
*{
margin: 0;
padding: 0;
box-sizing: border-box;
font-family: 'Poppins', sans-serif;
transition: all 0.4s ease;;
}
/* ===== Colours ===== */
:root{
--body-color: #E4E9F7;
--nav-color: #4070F4;
--side-nav: #010718;
--text-color: #FFF;
--search-bar: #F2F2F2;
--search-text: #010718;
}
body{
height: 100vh;
background-color: var(--body-color);
}
body.dark{
--body-color: #18191A;
--nav-color: #242526;
--side-nav: #242526;
--text-color: #CCC;
--search-bar: #242526;
}
nav{
position: fixed;
top: 0;
left: 0;
height: 70px;
width: 100%;
background-color: var(--nav-color);
z-index: 100;
}
body.dark nav{
border: 1px solid #393838;
}
nav .nav-bar{
position: relative;
height: 100%;
max-width: 1000px;
width: 100%;
background-color: var(--nav-color);
margin: 0 auto;
padding: 0 30px;
display: flex;
align-items: center;
justify-content: space-between;
}
nav .nav-bar .sidebarOpen{
color: var(--text-color);
font-size: 25px;
padding: 5px;
cursor: pointer;
display: none;
}
nav .nav-bar .logo a{
font-size: 25px;
font-weight: 500;
color: var(--text-color);
text-decoration: none;
}
.menu .logo-toggle{
display: none;
}
.nav-bar .nav-links{
display: flex;
align-items: center;
}
.nav-bar .nav-links li{
margin: 0 5px;
list-style: none;
}
.nav-links li a{
position: relative;
font-size: 17px;
font-weight: 400;
color: var(--text-color);
text-decoration: none;
padding: 10px;
}
.nav-links li a::before{
content: '';
position: absolute;
left: 50%;
bottom: 0;
transform: translateX(-50%);
height: 6px;
width: 6px;
border-radius: 50%;
background-color: var(--text-color);
opacity: 0;
transition: all 0.3s ease;
}
.nav-links li:hover a::before{
opacity: 1;
}
.nav-bar .darkLight-searchBox{
display: flex;
align-items: center;
}
.darkLight-searchBox .dark-light,
.darkLight-searchBox .searchToggle{
height: 40px;
width: 40px;
display: flex;
align-items: center;
justify-content: center;
margin: 0 5px;
}
.dark-light i,
.searchToggle i{
position: absolute;
color: var(--text-color);
font-size: 22px;
cursor: pointer;
transition: all 0.3s ease;
}
.dark-light i.sun{
opacity: 0;
pointer-events: none;
}
.dark-light.active i.sun{
opacity: 1;
pointer-events: auto;
}
.dark-light.active i.moon{
opacity: 0;
pointer-events: none;
}
.searchToggle i.cancel{
opacity: 0;
pointer-events: none;
}
.searchToggle.active i.cancel{
opacity: 1;
pointer-events: auto;
}
.searchToggle.active i.search{
opacity: 0;
pointer-events: none;
}
.searchBox{
position: relative;
}
.searchBox .search-field{
position: absolute;
bottom: -85px;
right: 5px;
height: 50px;
width: 300px;
display: flex;
align-items: center;
background-color: var(--nav-color);
padding: 3px;
border-radius: 6px;
box-shadow: 0 5px 5px rgba(0, 0, 0, 0.1);
opacity: 0;
pointer-events: none;
transition: all 0.3s ease;
}
.searchToggle.active ~ .search-field{
bottom: -74px;
opacity: 1;
pointer-events: auto;
}
.search-field::before{
content: '';
position: absolute;
right: 14px;
top: -4px;
height: 12px;
width: 12px;
background-color: var(--nav-color);
transform: rotate(-45deg);
z-index: -1;
}
.search-field input{
height: 100%;
width: 100%;
padding: 0 45px 0 15px;
outline: none;
border: none;
border-radius: 4px;
font-size: 14px;
font-weight: 400;
color: var(--search-text);
background-color: var(--search-bar);
}
body.dark .search-field input{
color: var(--text-color);
}
.search-field i{
position: absolute;
color: var(--nav-color);
right: 15px;
font-size: 22px;
cursor: pointer;
}
body.dark .search-field i{
color: var(--text-color);
}
@media (max-width: 790px) {
nav .nav-bar .sidebarOpen{
display: block;
}
.menu{
position: fixed;
height: 100%;
width: 320px;
left: -100%;
top: 0;
padding: 20px;
background-color: var(--side-nav);
z-index: 100;
transition: all 0.4s ease;
}
nav.active .menu{
left: -0%;
}
nav.active .nav-bar .navLogo a{
opacity: 0;
transition: all 0.3s ease;
}
.menu .logo-toggle{
display: block;
width: 100%;
display: flex;
align-items: center;
justify-content: space-between;
}
.logo-toggle .siderbarClose{
color: var(--text-color);
font-size: 24px;
cursor: pointer;
}
.nav-bar .nav-links{
flex-direction: column;
padding-top: 30px;
}
.nav-links li a{
display: block;
margin-top: 20px;
}
}
jаvascript КОД:
const body = document.querySelector("body"),
nav = document.querySelector("nav"),
modeToggle = document.querySelector(".dark-light"),
searchToggle = document.querySelector(".searchToggle"),
sidebarOpen = document.querySelector(".sidebarOpen"),
siderbarClose = document.querySelector(".siderbarClose");
let getMode = localStorage.getItem("mode");
if(getMode && getMode === "dark-mode"){
body.classList.add("dark");
}
// js code to toggle dark and light mode
modeToggle.addEventListener("click" , () =>{
modeToggle.classList.toggle("active");
body.classList.toggle("dark");
// js code to keep user selected mode even page refresh or file reopen
if(!body.classList.contains("dark")){
localStorage.setItem("mode" , "light-mode");
}else{
localStorage.setItem("mode" , "dark-mode");
}
});
// js code to toggle search box
searchToggle.addEventListener("click" , () =>{
searchToggle.classList.toggle("active");
});
// js code to toggle sidebar
sidebarOpen.addEventListener("click" , () =>{
nav.classList.add("active");
});
body.addEventListener("click" , e =>{
let clickedElm = e.target;
if(!clickedElm.classList.contains("sidebarOpen") && !clickedElm.classList.contains("menu")){
nav.classList.remove("active");
}
});
Давайте бегло взглянем на данное изображение нашей строки меню навигации.
В верхней части мы видим меню панели навигации. С правой стороны мы видим логотип, в центре несколько навигационных ссылок, а с левой стороны мы видим темный светлый режим и кнопку переключения панели поиска. На самом деле это облегченная версия навигационной панели, и, нажав кнопку переключения темного и светлого цвета, мы можем применить темный режим.
Как вы видели в видеоуроке, сначала мы увидели, что наше навигационное меню расположено в верхней части веб-страницы. В строке меню навигации мы видим логотип справа, несколько навигационных ссылок в центре и режим «день-ночь», а также кнопку переключения панели поиска слева.
Кроме того, я показал им, как панель поиска появляется и исчезает при нажатии кнопки переключения. Вы заметили? наш примененный режим (темный или светлый) не изменился, даже если я обновил веб-страницу или снова открыл файл.
Дизайн пользовательского интерфейса навигационного меню выполнен с использованием HTML и CSS, а функция переключения панели поиска и режима темного света я использовал некоторый код jаvascript, а для сохранения выбранного пользователем режима (темный свет) я использовал локальное хранилище.
Я надеюсь, что теперь вы можете легко создать эту панель меню навигации. Если у вас возникли трудности с созданием этой панели навигации, я предоставил весь HTML-код CSS и jаvascript для этой панели навигации ниже;
Чтобы получить следующий HTML-код CSS и jаvascript для панели навигации с функциями темного/светлого режима. Вам необходимо создать два файла: один — HTML-файл, а другой — CSS-файл. После создания этих двух файлов вы можете скопировать и вставить данные коды в свой документ. Вы также можете скачать все файлы исходного кода с помощью данной кнопки загрузки.