<!doctype html> <html> <head> <meta charset='utf-8'> <meta name='viewport' content='width=device-width, initial-scale=1'> <title>Advanced Drop-down Menu using HTML CSS and JavaScript</title> <link href='https://use.fontawesome.com/releases/v5.7.2/css/all.css' rel='stylesheet'> </head> <body> <nav> <div class="drop-btn"> Drop down <span class="fas fa-caret-down"></span> </div> <div class="tooltip"></div> <div class="wrapper"> <ul class="menu-bar"> <li> <a href="#"> <div class="icon"> <span class="fas fa-home"></span> </div> Home </a> </li> <li class="setting-item"> <a href="#"> <div class="icon"> <span class="fas fa-cog"></span> </div> Settings & privacy <i class="fas fa-angle-right"></i> </a> </li> <li class="help-item"> <a href="#"> <div class="icon"> <span class="fas fa-question-circle"></span> </div> Help & support <i class="fas fa-angle-right"></i> </a> </li> <li> <a href="#"> <div class="icon"> <span class="fas fa-user"></span> </div> About us </a> </li> <li> <a href="#"> <div class="icon"> <span class="fas fa-comment-alt"></span> </div> Feedback </a> </li> </ul> <!-- Settings & privacy Menu-items --> <ul class="setting-drop"> <li class="arrow back-setting-btn"><span class="fas fa-arrow-left"></span>Settings & privacy</li> <li> <a href="#"> <div class="icon"> <span class="fas fa-user"></span> </div> Personal info </a> </li> <li> <a href="#"> <div class="icon"> <span class="fas fa-lock"></span> </div> Password </a> </li> <li> <a href="#"> <div class="icon"> <span class="fas fa-address-book"></span> </div> Activity log </a> </li> <li> <a href="#"> <div class="icon"> <span class="fas fa-globe-asia"></span> </div> Languages </a> </li> <li> <a href="#"> <div class="icon"> <span class="fas fa-sign-out-alt"></span> </div> Log out </a> </li> </ul> <!-- Help & support Menu-items --> <ul class="help-drop"> <li class="arrow back-help-btn"><span class="fas fa-arrow-left"></span>Help & support</li> <li> <a href="#"> <div class="icon"> <span class="fas fa-question-circle"></span> </div> Help centre </a> </li> <li> <a href="#"> <div class="icon"> <span class="fas fa-envelope"></span> </div> Support Inbox </a> </li> <li> <a href="#"> <div class="icon"> <span class="fas fa-comment-alt"></span> </div> Send feedback </a> </li> <li> <a href="#"> <div class="icon"> <span class="fas fa-exclamation-circle"></span> </div> Report problem </a> </li> </ul> </div> </nav> <script type='text/javascript' src='https://cdn.jsdelivr.net/npm/popper.js@1.16.0/dist/umd/popper.min.js'></script> </body> </html>
@import url('https://fonts.googleapis.com/css?family=Poppins:400,500,600,700&display=swap'); * { margin: 0; padding: 0; box-sizing: border-box; user-select: none; font-family: 'Poppins', sans-serif; } body { background: #18191A; overflow: hidden; } nav { position: absolute; top: 30%; left: 50%; transform: translate(-50%, -50%); } nav .drop-btn { width: 400px; background: #242526; border-radius: 5px; line-height: 55px; font-size: 20px; font-weight: 500; color: #b0b3b8; padding: 0 20px; } nav .drop-btn span { float: right; line-height: 50px; font-size: 28px; cursor: pointer; } nav .tooltip { position: absolute; right: 20px; bottom: -20px; height: 15px; width: 15px; background: #242526; ; transform: rotate(45deg); display: none; } nav .tooltip.show { display: block; } nav .wrapper { position: absolute; top: 65px; display: flex; width: 400px; overflow: hidden; border-radius: 5px; background: #242526; display: none; transition: all 0.3s ease; } nav .wrapper.show { display: block; display: flex; } .wrapper ul { width: 400px; list-style: none; padding: 10px; transition: all 0.3s ease; } .wrapper ul li { line-height: 55px; } .wrapper ul li a { position: relative; color: #b0b3b8; font-size: 18px; font-weight: 500; padding: 0 10px; display: flex; border-radius: 8px; align-items: center; text-decoration: none; } .wrapper ul li:hover a { background: #3A3B3C; } ul li a .icon { height: 40px; width: 40px; margin-right: 13px; background: #ffffff1a; display: flex; justify-content: center; text-align: center; border-radius: 50%; } ul li a .icon span { line-height: 40px; font-size: 20px; color: #b0b3b8; } ul li a i { position: absolute; right: 10px; font-size: 25px; pointer-events: none; } .wrapper ul.setting-drop, .wrapper ul.help-drop { display: none; } .wrapper .arrow { padding-left: 10px; font-size: 20px; font-weight: 500; color: #b0b3b8; cursor: pointer; } .wrapper .arrow span { margin-right: 15px; }
const drop_btn = document.querySelector(".drop-btn span"); const tooltip = document.querySelector(".tooltip"); const menu_wrapper = document.querySelector(".wrapper"); const menu_bar = document.querySelector(".menu-bar"); const setting_drop = document.querySelector(".setting-drop"); const help_drop = document.querySelector(".help-drop"); const setting_item = document.querySelector(".setting-item"); const help_item = document.querySelector(".help-item"); const setting_btn = document.querySelector(".back-setting-btn"); const help_btn = document.querySelector(".back-help-btn"); drop_btn.onclick = (() => { menu_wrapper.classList.toggle("show"); tooltip.classList.toggle("show"); }); setting_item.onclick = (() => { menu_bar.style.marginLeft = "-400px"; setTimeout(() => { setting_drop.style.display = "block"; }, 100); }); help_item.onclick = (() => { menu_bar.style.marginLeft = "-400px"; setTimeout(() => { help_drop.style.display = "block"; }, 100); }); setting_btn.onclick = (() => { menu_bar.style.marginLeft = "0px"; setting_drop.style.display = "none"; }); help_btn.onclick = (() => { help_drop.style.display = "none"; menu_bar.style.marginLeft = "0px"; });
This snippet creates a visually appealing and functional nested drop-down menu using CSS and JavaScript. The menu allows users to navigate through multiple levels of options, providing a well-organized and user-friendly interface.
Key Features:
- Responsive Design: The menu adapts seamlessly to different screen sizes, ensuring a consistent user experience across devices.
- Customizable Styling: Easily modify the appearance of the menu using CSS to match your website's design and branding.
- Nested Levels: The menu supports multiple levels of nesting, allowing you to create complex navigation structures.
- Smooth Animations: The menu incorporates smooth animations for a visually appealing and engaging user experience.
- JavaScript Functionality: JavaScript is used to handle the menu's behavior, such as opening and closing submenus and preventing default link behavior.
Implementation:
- Create the HTML Structure: Set up the basic HTML structure for the menu, including the container, parent menu items, and nested submenu items.
- Apply CSS Styles: Use CSS to style the menu elements, such as the container, menu items, submenus, and arrow icons. Customize the colors, fonts, and spacing to match your website's design.
- Add JavaScript Functionality: Implement JavaScript code to handle the menu's behavior, including opening and closing submenus and preventing default link behavior. You can use event listeners and CSS classes to achieve this.
data:image/s3,"s3://crabby-images/deeb4/deeb4d22b637c974daf97b1f4da97225ba07e0d3" alt="DocsAllOver - Stylish Tailwind Contact Form with Image in Tailwind CSS"
Stylish Contact Form with Image in Tailwind CSS
data:image/s3,"s3://crabby-images/48663/48663fa1bc751f7e739e5084fd13b4e6a1ca1c00" alt="DocsAllOver - Responsive Registration Form with Image in Tailwind CSS"
Responsive Registration Form with Image in Tailwind CSS
data:image/s3,"s3://crabby-images/f036c/f036cb0b49215f99f03971adfbb41d23f7d6c785" alt="DocsAllOver - Bootstrap 5 Payment Method Form Page with Invoice"
Bootstrap 5 Payment Method Form Page with Invoice
data:image/s3,"s3://crabby-images/97ba8/97ba8f6e5d0bd280e64de426c5abf0bf689bd1ae" alt="DocsAllOver - Modern Pricing Table Design with Bootstrap 4"
Modern Pricing Table Design with Bootstrap 4
data:image/s3,"s3://crabby-images/5c68e/5c68e2bb86d78c8b0598633747c73d7a252dbd4f" alt="DocsAllOver - Responsive Multi-Level Drop-Down Navigation Menu in CSS"
Responsive Multi-Level Drop-Down Navigation Menu in CSS
data:image/s3,"s3://crabby-images/ffced/ffced1cda2c15dbb2618f751f6393fdd076cad3d" alt="DocsAllOver - Interactive Bottom Navigation Bar Indicator with CSS"
Interactive Bottom Navigation Bar Indicator with CSS
data:image/s3,"s3://crabby-images/bf8bb/bf8bbd07f939eae388959597aeb125c85502ff44" alt="DocsAllOver - Real-time Password Strength Indicator in Bootstrap 5"
Real-time Password Strength Indicator in Bootstrap 5
data:image/s3,"s3://crabby-images/0c62c/0c62c79460f3126b75b7ff142389ef489b7e77cc" alt="DocsAllOver - Responsive Video Card Component for Tailwind CSS"
Responsive Video Card Component for Tailwind CSS
data:image/s3,"s3://crabby-images/90335/90335426e9a6f5475d9a16bd5e8b63bff96d2a76" alt="DocsAllOver - Responsive Feature Highlight Component with Tailwind CSS"
Responsive Feature Highlight Component with Tailwind CSS
data:image/s3,"s3://crabby-images/ccda5/ccda5eeaa99235f1a338a5a30386bfede6bc1281" alt="DocsAllOver - Multi-Step Form with International Phone Input and Nice Select"
Multi-Step Form with International Phone Input and Nice Select
data:image/s3,"s3://crabby-images/883aa/883aa002196c88cdd51f1a804bff93dd3cb9dfc6" alt="DocsAllOver - Responsive Review Cards Component with CSS3"
Responsive Review Cards Component with CSS3
data:image/s3,"s3://crabby-images/3c21f/3c21ffa1ce5b4de45bb51f4a479bd7d31a476040" alt="DocsAllOver - Responsive CSS3 Timeline Design With Hover Effects"
Responsive CSS3 Timeline Design With Hover Effects
Building Blocks for Your Web Pages
Explore a collection of pre-written HTML,CSS and Javascript
snippets to jumpstart your web development projects.