How to create a Responsive Bottom Navigation Menu with CSS and JavaScript. Last Updated : 23 Jul, 2025 Comments Improve Suggest changes 1 Likes Like Report A responsive bottom navigation menu provides mobile-friendly access to important links. We will see how to create a responsive bottom navigation menu that adjusts to different screen widths. The menu will include elements like Home, Contact, and About. When viewed on a smaller screen, a hamburger menu appears, and clicking it displays the navigation options vertically. ApproachCreate a basic HTML structure with navigation links and a hamburger menu icon.Create a CSS file to style the navigation menu.Create a JavaScript file to handle the toggle functionality for the hamburger menu.Ensure that the navigation items appear horizontally on bigger screens and vertically when the hamburger menu is engaged on smaller screens.Test the navigation menu on various screen sizes to ensure responsiveness.Example: The example below shows how to create a responsive bottom navigation menu with CSS and JavaScript. HTML <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Responsive Bottom Navigation</title> <link rel="stylesheet" href="styles.css"> </head> <body> <div class="nav-container"> <div class="hamburger"> ☰ </div> <ul class="nav-items"> <li><a href="#home">Home</a></li> <li><a href="#contact">Contact</a></li> <li><a href="#about">About</a></li> </ul> </div> <script src="script.js"></script> </body> </html> CSS body { font-family: Arial, sans-serif; margin: 0; padding: 0; } .nav-container { position: fixed; bottom: 0; width: 100%; background-color: #333; } .nav-items { display: flex; justify-content: space-around; list-style: none; margin: 0; padding: 10px 0; } .nav-items li { color: white; } .nav-items li a { color: white; text-decoration: none; } .hamburger { display: none; font-size: 30px; color: white; padding: 10px; cursor: pointer; } @media (max-width: 600px) { .nav-items { display: none; flex-direction: column; background-color: #333; } .nav-items.active { display: flex; } .hamburger { display: block; text-align: center; } } JavaScript const hamburger = document.querySelector('.hamburger'); const navItems = document.querySelector('.nav-items'); hamburger.addEventListener('click', () => { navItems.classList.toggle('active'); }); Output: Create Quiz Comment P parthdollor Follow 1 Improve P parthdollor Follow 1 Improve Article Tags : JavaScript Web Technologies Explore JavaScript BasicsIntroduction to JavaScript4 min readVariables and Datatypes in JavaScript6 min readJavaScript Operators5 min readControl Statements in JavaScript4 min readArray & StringJavaScript Arrays7 min readJavaScript Array Methods7 min readJavaScript Strings5 min readJavaScript String Methods9 min readFunction & ObjectFunctions in JavaScript5 min readJavaScript Function Expression3 min readFunction Overloading in JavaScript4 min readObjects in JavaScript4 min readJavaScript Object Constructors4 min readOOPObject Oriented Programming in JavaScript3 min readClasses and Objects in JavaScript4 min readWhat Are Access Modifiers In JavaScript ?5 min readJavaScript Constructor Method7 min readAsynchronous JavaScriptAsynchronous JavaScript2 min readJavaScript Callbacks4 min readJavaScript Promise4 min readEvent Loop in JavaScript4 min readAsync and Await in JavaScript2 min readException HandlingJavascript Error and Exceptional Handling6 min readJavaScript Errors Throw and Try to Catch2 min readHow to create custom errors in JavaScript ?2 min readJavaScript TypeError - Invalid Array.prototype.sort argument1 min readDOMHTML DOM (Document Object Model)8 min readHow to select DOM Elements in JavaScript ?3 min readJavaScript Custom Events4 min readJavaScript addEventListener() with Examples9 min readAdvanced TopicsClosure in JavaScript4 min readJavaScript Hoisting6 min readScope of Variables in JavaScript3 min readJavaScript Higher Order Functions7 min readDebugging in JavaScript4 min read Like