La navegación adaptable basada en Flexbox de CSS
| Autor: | mburakerman |
|---|---|
| Views Total: | 5,547 |
| Sitio oficial: | Ir a la web |
| Actualizado: | March 8, 2017 |
| Licencia: | MIT |
Vista prévia
Descripción
Un CSS sólo responsive navegación del sitio que convierte automáticamente el Nav horizontal normal en un menú de hamburguesa deslizante. Basado en la transición CSS, Flexbox y CheckBox + trucos de etiqueta.
Funcionamiento
Agregue su lista de menú con un botón de alternancia de hamburguesa en su elemento de navegación:
<nav> <input type="checkbox" id="checkbox-demo"> <label for="checkbox-demo"> <ul class="menu demo"> <li><a href="#">HOME</a></li> <li><a href="#">ABOUT</a></li> <li><a href="#">CONTACT</a></li> <li><a href="#">BLOG</a></li> </ul> <span class="toggle">â°</span> </label> </nav>
Estilo del menú de navegación horizontal normal.
nav {
margin: 50px auto;
max-width: 700px;
width: 95%;
font-family: 'Roboto Condensed', sans-serif;
}
#checkbox1,
.toggle {
display: none;
}
.menu {
padding: 0;
margin: 0;
max-width: 700px;
height: 50px;
border-radius: 5px;
display: flex;
flex-direction: row;
justify-content: space-around;
align-items: center;
list-style-type: none;
}
.menu li a {
text-decoration: none;
align-self: center;
border-radius: 5px;
font-size: 14px;
padding: 10px 15px;
transition: background .2s linear;
} Estilo del menú de hamburguesas en pantallas pequeñas.
@media screen and (max-width: 600px) {
.menu li a {
font-size: 13px;
}
}
@media screen and (max-width: 550px) {
.toggle {
clear: both;
display: block;
text-align: center;
font-size: 14px;
line-height: 40px;
cursor: pointer;
width: 100%;
height: 40px;
font-size: 18px;
color: #595959;
background: #dbdbdb;
border-bottom-left-radius: 5px;
border-bottom-right-radius: 5px;
transition: all .1s linear;
}
.toggle:hover {
background: #cecece;
}
#checkbox1:checked + label .demo li {
opacity: 1;
visibility: visible;
transition: all .7s linear;
}
#checkbox1:checked + label .demo {
height: 200px;
}
.menu {
border-radius: 0px;
border-top-left-radius: 5px;
border-top-right-radius: 5px;
display: flex;
flex-direction: column;
justify-content: space-around;
align-items: center;
height: 0px;
transition: height .3s linear;
}
.menu li {
display: flex;
/* magic */
align-self: center;
width: 95%;
opacity: 0;
visibility: hidden;
}
.menu li a {
width: 95%;
text-align: center;
align-self: center;
align-content: center;
}
}





