Responsive navbar CSS and JS

Last updated: June 29, 2025

What is response navbar?

A responsive navbar is a navigation menu on a website that automatically adjusts and adapts its layout and appearance based on the screen size and device being used. It is designed to provide an optimal user experience, ensuring that the navigation remains easily accessible and usable on different devices, such as desktops, tablets, and mobile phones. The responsive navbar utilizes CSS and JavaScript techniques to dynamically rearrange and resize the menu items, making it easier for users to navigate the website regardless of the device they are using.

 

Method of responsive navbar:

  1. CSS Media Queries: Utilize CSS media queries to define different styles and layout rules for different screen sizes. Adjust the navbar's appearance and behavior based on breakpoints to ensure responsiveness.
  2. Flexbox: Utilize CSS Flexbox properties to create a flexible and responsive navbar layout. Flexbox allows you to easily distribute and align navbar items, making them adapt to different screen sizes.
  3. CSS Grid: Implement CSS Grid to create a responsive grid-based navbar. CSS Grid enables you to create multiple columns and rows, allowing you to organize navbar elements effectively and responsively.
  4. JavaScript DOM Manipulation: Use JavaScript to dynamically manipulate the navbar elements based on the screen size. You can add event listeners, modify CSS classes, or change styles to make the navbar responsive.

 

In this article, we will create a responsive navbar using CSS and JavaScript. CSS Flexbox and JavaScript were used to create a responsive navbar. Flexbox will be used for responsiveness, and JavaScript will be used for handling click events on the hamburger menu.

 

Output:

Responsive navbar CSS and JS computer view
Responsive navbar CSS and JS mobile view

Getting start from html:

Here use fontawesome is used for icons.

<!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">
	<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css"
		integrity="sha512-iecdLmaskl7CVkqkXNQ/ZH/XLlvWZOJyj7Yy7tcenmpD1ypASozpmT/E0iPtmFIB46ZmdtAc9eNBvH0H/ZpiBw=="
		crossorigin="anonymous" referrerpolicy="no-referrer" />
	<title>Responsive Navbar</title>

</head>

<body>
	<header>
		<div class="navbar">
			<div class="header-button">
				<label for="toggle_input" id="toggle_label"><i class="fa-solid fa-bars"></i></label>
                <input type="checkbox" id="toggle_input" value="false" onchange="toggle_button()">
                <img src="favicon.ico" alt="">
				<h1>OpenResume.com</h1>
			</div>
			<ul id="nav_ul">
				<li><a href="#">Home</a></li>
				<li><a href="#">Contact</a></li>
				<li><a href="#">Login</a></li>
                <form>
                    <input type="text" placeholder="Search..." name="search">
                </form>
			</ul>

		</div>
	</header>


</body>

</html>
*{
    margin: 0px;
    box-sizing: border-box;
    font-size: 20px;
}
header {
    padding: 0.5rem;
    background: #23384E;
}
header .navbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
header .navbar .header-button {
    display: flex;
    align-items: center;
}

header .navbar h1 {
    color: white;
    font-size: 1.3rem;
    padding-left: 0.1rem;
}
header .navbar img {
    color: white;
    font-size: 1.3rem;
    padding-left: 0.3rem;
}
#nav_ul {
    display: flex;
    list-style: none;
}

header .navbar label {
    color: white;
    display: none;
}

.header-button input {
    display: none;
}

#nav_ul a {
    text-decoration: none;
    color: white;
    padding: 0.5rem;
}


#nav_ul form {
    margin-top: 0.3rem;
}
@media (max-width: 992px) {
    header .navbar {
        flex-direction: column;
        align-items: flex-start;
    }

    #nav_ul {
        flex-direction: column;
        padding-top: 0.3rem;
        display: none;
    }

    #nav_ul li {
        padding-top: 0.5rem;
    }

    header .navbar label {
        display: block;
    }
}
function toggle_button() {
			var checkbox = document.getElementById("toggle_input").checked
			console.log(checkbox)
			if (checkbox == true) {
				document.getElementById("toggle_label").innerHTML = '<i class="fa-solid fa-chevron-down"></i>'
				document.getElementById("nav_ul").style.display = "flex"
			} else {
				document.getElementById("toggle_label").innerHTML = '<i class="fa-solid fa-bars"></i>'
				document.getElementById("nav_ul").style.display = "none"
			}
}
window.onresize = (event) => {
			if (document.getElementsByTagName("body")[0].clientWidth > 992) {
				document.getElementById("toggle_input").checked = false
				document.getElementById("toggle_label").innerHTML = '<i class="fa-solid fa-bars"></i>'
				document.getElementById("nav_ul").style.display = "flex"
			}
			else {
				toggle_button()
			}
}

105 comments

By Tobiasallef
May 15, 2024, 5:48 p.m.
Hi there! educodiv.com Did you know that it is possible to send appeals legally and legitimately? We propose a progressive method of sending business proposals through contact forms. As Communication Forms are seen as important, messages sent via them are less likely to be considered spam. We are now offering you the chance to use our service for free. We are able to transmit up to 50,000 messages for you. The cost of sending one million messages is $59. This message was automatically generated. Please use the contact details below to get in touch with us. Contact us. Telegram - https://t.me/FeedbackFormEU Skype live:feedbackform2019 WhatsApp +375259112693 WhatsApp https://wa.me/+375259112693 We only use chat for communication.
By profession_fxmt
Aug. 12, 2024, 11:26 p.m.
Как выбрать профессиональный 3D сканер для работы 3d сканер профессиональный [url=profes-3d-skan.ru]profes-3d-skan.ru[/url] .
By Tommygob
April 28, 2025, 5:25 a.m.
hi
By Alaric Ong
July 18, 2024, 1:28 p.m.
Hi, My mentor Alaric Ong is a million-dollar funnel builder with a proven track record of generating leads, appointments, and sales automatically. He has driven millions of dollars in revenue through his own funnels. Our strategy allows us to achieve a cost per lead of $3 to $10 in competitive markets and $20 to $30 per appointment. The key to our success is running thousands of variations of ads, preventing ad fatigue and reducing costs. Most marketers run only a few ads, causing them to quickly lose effectiveness. We use AI to split test and optimize our ads, ensuring we spend more on successful ads and less on underperforming ones. This approach results in leads costing $10 each and appointments costing $30 in Singapore. In Malaysia, we achieve appointments at RM 9.94 (SGD $3). In USA, $20 per appointment If you’re interested in learning more, visit https://funnel.alaric.ai. Best, Alaric WhatsApp: https://wa.link/z7f073 Email: alaricong123@gmail.com 1000+ Client results: http://alaric.site/wins Hundreds of Testimonials: https://alaricong.com/p/testimonials.html Join our WhatsApp group: https://chat.whatsapp.com/Ln6E1UBammC6MOzcXhXYlN
By kaAdvamma
March 1, 2025, 9:11 a.m.
Unlock Bitcoin Cash. $8252 Ready Now - https://t.me/+HkY2o13tXmtjY2My?Drek31lef
By Promyshlen_uqEa
Aug. 11, 2024, 9:47 p.m.
Как улучшить процесс проектирования с применением 3D-сканеров 3d принтер промышленный купить [url=https://www.myshlennye-3d-ska4.ru/]https://www.myshlennye-3d-ska4.ru/[/url] .
By BroRah
Oct. 17, 2024, 11:45 p.m.
The manufacturer of Ozempic and Wegovy has released a new version of the drug for weight loss, in the form of Rybelsus tablets with the same active ingredient Semaglutide. Rybelsus will help you lose weight quickly with a guarantee. What Is Rybelsus? Rybelsus is an oral (tablet) medication used to treat and manage Type 2 Diabetes, and for the treatment of weight loss. The active ingredient is Semaglutide which mimics the action of one of your bodies natural hormones (GLP1). It contains the same ingredient as Ozempic, which is a once weekly injection. Unlike the injections, Rebelsus is a tablet which is taken once daily. Multiple clinical studies have found patients on Rybelsus lose up their body weight. Patients also saw significant reductions in waist size and other measurements. https://rybelsus.true-pill.top/
By Online_gpPn
Jan. 13, 2025, 3:48 a.m.
Explore the top-ranked online schools in Illinois, browse through the list of online schools. Earn your degree from a reputable online school in Illinois. Engaging professors and supportive academic environment. Take the first step towards your online degree. Online degrees in various fields of study. Approved online colleges in Illinois. Affordable online education options in Illinois. Online schools with high graduation rates. Advance your career with an online degree in Illinois. Connect with like-minded individuals in online programs in Illinois. Online Schools in Illinois [url=http://onlineschoolil20.com/]http://onlineschoolil20.com/[/url] .

Create new comment