Create a responsive design sliding side navigation menu
In this tutorial, you will create an expandable side navigation menu using JavaScript and CSS. The final product is shown below:
1. Create tag
First, let’s add some markup to the side menu:
<div id="sideNavigation" class="sidenav"> <a href="#" class="close-btn">×</a> <a href="#">About</a> <a href="#">Features</a> <a href="#">Contact Us</a> </div> <nav class="topnav"> <a href="#" class="ham-icon"> <svg width="30" height="30" id="icoOpen"> <path d="M0,5 30,5" stroke="#000" stroke-width="5"/> <path d="M0,14 30,14" stroke="#000" stroke-width="5"/> <path d="M0,23 30,23" stroke="#000" stroke-width="5"/> </svg> </a> </nav> <section id="main"> <h1 id="This-Side-Navigation-Menu-Looks-Good">This Side Navigation Menu Looks Good!</h1> <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p> </section>
Here you can see that we have created a side menu div
using class sidenav
. Next, we added the actual top bar navigation via the <nav>
tags, and we used SVG for the side menu icon.
Remember to put all the content of your website into a div id="main"
container so that it slides to the right.
2.Writing JavaScript code
Next, let's add JavaScript that will use the ham-icon
class to listen for click events on the hamburger icon, as well as the close button that appears after the side navigation menu slides onto the screen.
document.querySelector("a.ham-icon").addEventListener("click", function(event){ document.getElementById("sideNavigation").style.width = "250px"; document.getElementById("main").style.marginLeft = "250px"; }); document.querySelector("a.close-btn").addEventListener("click", function(event){ document.getElementById("sideNavigation").style.width = "0"; document.getElementById("main").style.marginLeft = "0"; });
Clicking on the hamburger icon should reveal the side navigation. To do this, we set the width of the navigation to 250px
while adding a left margin of 250px
to the main site content.
Clicking the close button should hide the side navigation. To do this, we change the width of the navigation back to 0, while also setting the left margin of the main site content to 0.
3. Using CSS styles
Finally, we need to use some CSS to style the side menu and links on the page. CSS will place all web page elements exactly where we want them. We will also apply some simple animation with the help of transition
properties. Let's look at CSS one part at a time.
.sidenav { height: 100%; width: 0; position: fixed; z-index: 1; top: 0; left: 0; background-color: #111; overflow-x: hidden; padding-top: 4rem; transition: 0.4s cubic-bezier(0.18, 0.89, 0.32, 1.28); font-family: "Bebas Neue"; } .sidenav a { padding: 0.5rem 1rem; text-decoration: none; color: #bdbdbd; display: block; transition: 0.4s; white-space: nowrap; font-size: 2rem; } .sidenav a:hover { color: white; background: #9e9e9e; }
We set the side navigation's height
to 100%
and its initial width
to 0
to make it hide. However, the content of the side navigation will remain hidden only if the value of the overflow-x
attribute is set to hidden
.
The transition property ensures that changes in side navigation width don't happen suddenly, and the easing feature makes it a bit elastic.
For links within the side navigation, we set the value of the white-space
attribute to nowrap
so that the menu text does not overflow multiple lines.
.sidenav .close-btn { position: absolute; top: -1rem; right: 1rem; font-size: 5rem; } .sidenav .close-btn:hover { background: initial; transform: scale(1.2); }
The CSS styling above separates our close button from the other links in the side navigation. We applied absolute positioning to the close button and prevented its background from turning light gray on hover. It also increases in size by 20% when the user hovers over it.
The following CSS will now ensure that the main content position moves in sync with the navigation menu by using the same transition duration and the same easing function. Setting the value of the overflow-x
property to hidden
ensures that horizontal scroll bars do not appear as content moves.
#main { transition: margin-left 0.4s cubic-bezier(0.18, 0.89, 0.32, 1.28); padding: 20px; width: 100%; } body { overflow-x: hidden; }
We can also add a little rotational movement to the hamburger icon with the help of the following CSS. It rotates the hamburger icon 180 degrees in 0.5 seconds.
a svg { transition: all 0.5s ease; } a svg:hover { transform: rotate(180deg); }
Finally, let’s make the navigation menu responsive by adjusting the spacing and size of the links using the following CSS. It ensures that the menu does not stretch out of scope on screens with less vertical space.
@media screen and (max-height: 480px) { .sidenav { padding-top: 3rem; } .sidenav a { font-size: 1.5rem; } }
At this point your navigation menu should look similar to the following CodePen demo.
4. Remove slideshow
To make the menu appear without slide animation, simply change the CSS property transition
, as shown in the abbreviated form below:
.sidenav { transition: 0s; } #main { transition: margin-left 0s; }
This will make the changes appear immediately since there is no delay specified in transition
. The default value we use is 0.5s
.
in conclusion
Creating a side menu only requires a few lines of code and does not require the use of many resources. Make your code responsive to different device screen resolutions by modifying your CSS by adding media queries for your specific cases.
To take it a step further, you may want to use a CSS framework like Bootstrap or Bulma to style your menu.
This article has been updated with a contribution from Monty Shokeen. Monty is a full-stack developer who also enjoys writing tutorials and learning new JavaScript libraries.
The above is the detailed content of Create a responsive design sliding side navigation menu. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



WordPress is easy for beginners to get started. 1. After logging into the background, the user interface is intuitive and the simple dashboard provides all the necessary function links. 2. Basic operations include creating and editing content. The WYSIWYG editor simplifies content creation. 3. Beginners can expand website functions through plug-ins and themes, and the learning curve exists but can be mastered through practice.

WordPressisgoodforvirtuallyanywebprojectduetoitsversatilityasaCMS.Itexcelsin:1)user-friendliness,allowingeasywebsitesetup;2)flexibilityandcustomizationwithnumerousthemesandplugins;3)SEOoptimization;and4)strongcommunitysupport,thoughusersmustmanageper

Can learn WordPress within three days. 1. Master basic knowledge, such as themes, plug-ins, etc. 2. Understand the core functions, including installation and working principles. 3. Learn basic and advanced usage through examples. 4. Understand debugging techniques and performance optimization suggestions.

Wix is suitable for users who have no programming experience, and WordPress is suitable for users who want more control and expansion capabilities. 1) Wix provides drag-and-drop editors and rich templates, making it easy to quickly build a website. 2) As an open source CMS, WordPress has a huge community and plug-in ecosystem, supporting in-depth customization and expansion.

WordPress itself is free, but it costs extra to use: 1. WordPress.com offers a package ranging from free to paid, with prices ranging from a few dollars per month to dozens of dollars; 2. WordPress.org requires purchasing a domain name (10-20 US dollars per year) and hosting services (5-50 US dollars per month); 3. Most plug-ins and themes are free, and the paid price ranges from tens to hundreds of dollars; by choosing the right hosting service, using plug-ins and themes reasonably, and regularly maintaining and optimizing, the cost of WordPress can be effectively controlled and optimized.

People choose to use WordPress because of its power and flexibility. 1) WordPress is an open source CMS with strong ease of use and scalability, suitable for various website needs. 2) It has rich themes and plugins, a huge ecosystem and strong community support. 3) The working principle of WordPress is based on themes, plug-ins and core functions, and uses PHP and MySQL to process data, and supports performance optimization.

WordPress is a Content Management System (CMS). It provides content management, user management, themes and plug-in capabilities to support the creation and management of website content. Its working principle includes database management, template systems and plug-in architecture, suitable for a variety of needs from blogs to corporate websites.

The core version of WordPress is free, but other fees may be incurred during use. 1. Domain names and hosting services require payment. 2. Advanced themes and plug-ins may be charged. 3. Professional services and advanced features may be charged.
