Italian (Italiano) translation by Francesco Turlon (you can also view the original English article)
In questo tutorial realizzerete un menu di navigazione laterale espandibile tramite JavaScript e CSS. Il risultato finale sarà il seguente:

Markup
Per iniziare, aggiungiamo del markup al nostro menu laterale:
<div id="sideNavigation" class="sidenav"> <a href="javascript:void(0)" class="closebtn" onclick="closeNav()">×</a> <a href="#">About</a> <a href="#">Features</a> <a href="#">Contact Us</a> </div> <nav class="topnav"> <a href="#" onclick="openNav()"> <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> <div id="main"> <!-- Add all your websites page content here --> </div>
Qui si vede che abbiamo creato un menu laterale div con classe sidenav
. Successivamente abbiamo aggiunto la barra di navigazione superiore mediante un tag <nav>
, e stiamo usando un SVG per l'icona del menu laterale.
L'attributo onclick
dell'icona e il pulsante di chiusura attiveranno del codice JavaScript, che aggiungeremo poi.
Ricordate di inserire tutto il contenuto del sito all'interno del container div id="main"
in modo che slitti a destra.
JavaScript
In seguito, aggiungete il codice JavaScript per le funzioni openNav
e closeNav
.
<script> function openNav() { document.getElementById("sideNavigation").style.width = "250px"; document.getElementById("main").style.marginLeft = "250px"; } function closeNav() { document.getElementById("sideNavigation").style.width = "0"; document.getElementById("main").style.marginLeft = "0"; } </script>
CSS
Infine, dovremo dare stile alla nostra pagina con del CSS per il menu laterale e i nostri collegamenti:
/* The side navigation menu */ .sidenav { height: 100%; /* 100% Full-height */ width: 0; /* 0 width - change this with JavaScript */ position: fixed; /* Stay in place */ z-index: 1; /* Stay on top */ top: 0; left: 0; background-color: #111; /* Black*/ overflow-x: hidden; /* Disable horizontal scroll */ padding-top: 60px; /* Place content 60px from the top */ transition: 0.5s; /* 0.5 second transition effect to slide in the sidenav */ } /* The navigation menu links */ .sidenav a { padding: 8px 8px 8px 32px; text-decoration: none; font-size: 25px; color: #818181; display: block; transition: 0.3s } /* When you mouse over the navigation links, change their color */ .sidenav a:hover, .offcanvas a:focus{ color: #f1f1f1; } /* Position and style the close button (top right corner) */ .sidenav .closebtn { position: absolute; top: 0; right: 25px; font-size: 36px; margin-left: 50px; } /* Style page content - use this if you want to push the page content to the right when you open the side navigation */ #main { transition: margin-left .5s; padding: 20px; overflow:hidden; width:100%; } body { overflow-x: hidden; } /* Add a black background color to the top navigation */ .topnav { background-color: #333; overflow: hidden; } /* Style the links inside the navigation bar */ .topnav a { float: left; display: block; color: #f2f2f2; text-align: center; padding: 14px 16px; text-decoration: none; font-size: 17px; } /* Change the color of links on hover */ .topnav a:hover { background-color: #ddd; color: black; } /* Add a color to the active/current link */ .topnav a.active { background-color: #4CAF50; color: white; } /* On smaller screens, where height is less than 450px, change the style of the sidenav (less padding and a smaller font size) */ @media screen and (max-height: 450px) { .sidenav {padding-top: 15px;} .sidenav a {font-size: 18px;} } a svg{ transition:all .5s ease; &:hover{ #transform:rotate(180deg); } } #ico{ display: none; } .menu{ background: #000; display: none; padding: 5px; width: 320px; @include border-radius(5px); #transition: all 0.5s ease; a{ display: block; color: #fff; text-align: center; padding: 10px 2px; margin: 3px 0; text-decoration: none; background: #444; &:nth-child(1){ margin-top: 0; @include border-radius(3px 3px 0 0 ); } &:nth-child(5){ margin-bottom: 0; @include border-radius(0 0 3px 3px); } &:hover{ background: #555; } } }
Nota: body {overflow-x: hidden;}
è necessario per assicurare che uno scorrimento orizzontale non appaia quando questo viene utilizzato con il nostro CSS esistente.
Potete ora controllare il vostro menu e provarlo nel browser.
Utilizzando jQuery
Se volete creare il menu laterale JavaScript usando jQuery, potete farlo sostituendo il codice JavaScript fornito prima con la sezione seguente:
$('.topnav a').click(function(){ $('#sideNavigation').style.width = "250px"; $("#main").style.marginLeft = "250px"; }); $('.closebtn').click(function(){ $('#sideNavigation').style.width = "0"; $("#main").style.marginLeft = "0"; });
Rimuovere la Slide
Per far apparire il menu senza animazione di scorrimento, modificate semplicemente la proprietà transition
in CSS, come mostrato in versione abbreviata qui sotto:
.sidenav { transition: 0s; } #main { transition: margin-left 0s; }
Ciò farà apparire la modifica istantaneamente dal momento che non è specificato alcun delay in transition
. Il parametro di default che abbiamo usato è 0.5s
.
Conclusione
Realizzare un menu laterale richiede poche righe di codice e non necessita l'utilizzo di molte risorse. Inoltre, se jQuery è già presente sulla pagina per altri compiti, il lavoro può essere svolto con ancora meno righe di codice e una personalizzazione maggiore.
Per rendere il codice responsive in modo da lavorare con diverse risoluzioni di schermo a seconda del dispositivo dovrete semplicemente modificare il CSS aggiungendo media queries per i casi specifici.
Per proseguire ulteriormente, potrete dare stile al vostro menu con un framework CSS come Bootstrap o Bulma.
Subscribe below and we’ll send you a weekly email summary of all new Code tutorials. Never miss out on learning about the next big thing.
Update me weeklyEnvato Tuts+ tutorials are translated into other languages by our community members—you can be involved too!
Translate this post