Carregando...

Como fazer um menu responsivo em html e css

Postado: 17 de março de 2023 Tempo de Leitura: 3 Minutos

Como fazer um menu responsivo em html e css

Neste tutorial vamos criar um  Menu responsivo com html e css.

Nesta seção, projetaremos uma estrutura simples na tag <div><nav><span>, <ul> <li> , <i> e a tag <href> para inserir o link de destino. 

Essas são as tags que usaremos para criar o nosso Menu responsivo.

Vamos Adicionar o HTML

        <!--Abre Nav-->
        <div class="wrapper">
        <nav class="nav">
    
            <div class="logo-menu">
              
              <div class="mob-menu">
                
                <div class="menu hamburger1">
                  <span></span>
                  <span></span>
                  <span></span>
                </div>

              </div>

            </div><!--Logo Menu-->

            <div class="nav-list-container">
              <div class="navbar">
                
                <ul class="nav-list">
                    
                    <li><a href="#" title="Home">Home</a></li>
                    <li><a href="#" title="Html">Html</a></li>
                    <li><a href="#" title="Css">Css</a></li>
                    <li><a href="#" title="Jquery">Jquery</a></li>
                    <li><a href="#" title="Wordpress">WordPress</a></li>
                    <li><a href="#" title="Contato">Contato</a></li>
                
                </ul>
                
                <ul class="nav-actions">
                  
                    <li>
                        <a href="#"> <i class="icon icon-facebook"></i> </a>
                    </li>
                  
                    <li>
                        <a href="#"> <i class="icon icon-instagram"></i> </a>
                    </li>

                    <li>
                        <a href="#"> <i class="icon icon-youtube"></i> </a>
                    </li>

                </ul>
              </div>
            </div>

        </nav>
        </div>
        <!--Fecha Nav-->

Vamos Adicionar o CSS

Nesta seção, usaremos algumas propriedades CSS para estilizar o nosso  Menu responsivo.

.wrapper .nav {
    
    display: flex;
    background-color: #fff;
    height: 60px;
    max-height: 60px;
    color: #4c4c4c;
    transition: all 0.35s ease;
    border-top: 1px #dedede solid;

}

.wrapper .nav .logo-menu {

    display: flex;
    justify-content: flex-end;
    align-items: center;
    height: 60px;

}

.wrapper .nav .logo-menu .mob-menu {
  display: none;
}

.wrapper .nav .logo-menu .mob-menu .menu {
  
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 30px;
  width: 36px;
  position: relative;
  cursor: pointer;
  transition: width 0.3s ease;
}

.wrapper .nav .logo-menu .mob-menu .menu span {

  display: inline-block;
  width: 100%;
  height: 2px;
  background-color: currentColor;
  transition: transform 0.4s ease, opacity 0.3s ease, transform-origin 0.3s ease;
  transform-origin: left;
}

.wrapper .nav .logo-menu .mob-menu .hamburger1.active {
  width: 40px;
}

.wrapper .nav .logo-menu .mob-menu .hamburger1.active span:nth-of-type(1) {
  transform: rotate(-45deg);
  transform-origin: right;
}
.wrapper .nav .logo-menu .mob-menu .hamburger1.active span:nth-of-type(2) {
  opacity: 0;
}
.wrapper .nav .logo-menu .mob-menu .hamburger1.active span:nth-of-type(3) {
  transform: rotate(45deg);
  transform-origin: right;
}


.wrapper .nav .nav-list-container {

  width: 100%;
}

.wrapper .nav .navbar {
  
  height: 100%;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  flex: 1 1 auto;

}

.wrapper .nav .navbar .nav-list, .wrapper .nav .navbar .nav-actions {

  display: flex;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0.25rem 0;
  gap: 0.25rem;

}

.wrapper .nav .navbar .nav-list li a, .wrapper .nav .navbar .nav-actions li a {

  display: inline-flex;
  align-items: center;
  padding: 0.5rem 0.75rem;
  text-decoration: none;
  color: inherit;
  border-radius: 0.25rem;

}

.wrapper .nav .navbar .nav-list li a:hover, .wrapper .nav .navbar .nav-actions li a:hover {

  background-color: #007cff;
  color: #fff;

}

.wrapper .nav .navbar .nav-actions {
 
  background: transparent;

}

.wrapper .nav .navbar .nav-actions li a {

    display: flex;
    align-items: center;
    padding: 10px;
    border-radius: 6;
    font-size: 1.1em;

}

@media (max-width: 768px) {
  
  .wrapper .nav {
    display: block;
    height: auto;
    max-height: unset;
  }

  .wrapper .nav .logo-menu {
    margin: 0 -1rem;
    padding: 0 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  }

  .wrapper .nav .logo-menu .mob-menu {
    display: block;
  }

  .wrapper .nav .navbar {
    flex-direction: column;
    align-items: unset;
    justify-content: unset;
  }

  .wrapper .nav .navbar .nav-list, .wrapper .nav .navbar .nav-actions {
    flex-direction: column;
    width: 100%;
  }

  .wrapper .nav .navbar .nav-list li, .wrapper .nav .navbar .nav-actions li {
    margin: 0.25rem 0;
    flex: 1 1 auto;
    width: 100%;
    text-align: center;
  }

  .wrapper .nav .navbar .nav-list li a, .wrapper .custom-nav .navbar .nav-actions li a {
    display: block;
  }

  .wrapper .nav .navbar .nav-actions {
    flex-direction: row;
    justify-content: space-between;
    border: unset;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    margin: 0.25rem 0;
  }

  .wrapper .nav .navbar .nav-actions li a {
    display: flex;
    border-radius: 0.25rem;
    justify-content: center;
    align-items: center;
  }
  
}

.wrapper .container {

  height: calc(100vh-60px);
  padding: 50px;
  text-align: center;

}

Vamos Adicionar um script básico para dar o efeito de toggle.

<script src="js/jquery.js"></script>
<script type="text/javascript">
    
    $(document).ready(function () {
      toggleNavbar();
      $(window).resize((event) => {
        if ($(window).width() > 768) {
          $(".nav-list-container").css("display", "flex");
          if ($(".hamburger1").hasClass("active")) {
            $(".hamburger1").removeClass("active");
          }
        }
      });
    });

    function toggleNavbar() {
      $(".mob-menu").on("click", (event) => {
        $(".hamburger1").toggleClass("active");
        $(".nav-list-container").animate(
          {
            height: "toggle"
          },
          500
        );
      });
    }

</script>

Combinando as Três seções acima com Html e Css temos o seguinte Resultado!

Veja o Resultado baixo!

Baixar Código Veja Funcionando

Publicado por: Loop Nerd

1.862 Visualizações

Deixe um comentário

O seu endereço de e-mail não será publicado. Campos obrigatórios são marcados com *

Artigos Relacionados