Carregando...

Efeitos de transições ao passar o mouse

Postado: 16 de março de 2023 Tempo de Leitura: 2 Minutos

Efeitos de transições ao passar o mouse

Neste tutorial vamos criar  Efeitos de transições ao passar o mouse com html e css.

A animação acontece quando o usuário passa o mouse sobre o item html formatado com CSS.

Nesta seção, projetaremos uma estrutura simples na tag <figure><img><figcaption>, <ul> <li> , <i> e a tag <href> para inserir o link de destino da Rede Social. 

Essas são as tags que usaremos para criar o nosso Efeito de transição ao passar o mouse .

Vamos Adicionar o HTML

    <figure class="card">
     
      <img src="uploads/foto.jpg" alt="Front-end" title="Front-end" />
      <figcaption>
       
        <h2>Front-end</h2>
        <ul class="links">
          <li> <a href="#"> <i class="icon icon-facebook"></i> Facebook</a></li>
          <li> <a href="#"> <i class="icon icon-instagram"></i> Instagram</a></li>
          <li> <a href="#"> <i class="icon icon-twitter"></i> Twitter</a></li>
          <li> <a href="#"> <i class="icon icon-youtube"></i> Youtube</a></li>
        </ul>

      </figcaption>
    </figure>

Vamos Adicionar o CSS

Nesta seção, usaremos algumas propriedades CSS para estilizar o nosso Efeito de transição na imagem.

figure.card {

  font-family: 'open_sansregular';
  position: relative;
  overflow: hidden;
  margin: auto;
  min-width: 230px;
  max-width: 315px;
  max-height: 230px;
  width: 100%;
  color: #ffffff;
  text-align: left;
  font-size: 16px;
  background-color: #000000;
  border-radius: 8px;

}

figure.card:after {

  position: absolute;
  top: 0;
  bottom: 0;
  left: -100%;
  right: -20%;
  content: '';
  background-color: rgba(4, 104, 232, 0.66);
  -webkit-transform: skew(20deg) translateX(-75%);
  transform: skew(20deg) translateX(-75%);
  -webkit-transition: all 0.50s ease;
  transition: all 0.50s ease;

}

figure.card * {

  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all 0.35s ease;
  transition: all 0.35s ease;

}

figure.card img {

  max-width: 100%;

}

figure.card figcaption {

  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  padding: 20px;

}

figure.card h2,
figure.card .links {

  width: 100%;
  margin: 0;
  padding: 0;

}

figure.card h2 {

  line-height: 1.3em;
  font-weight: bold;
  font-size: 1.3em;
  margin-bottom: 12px;

}

figure.card .links {
  
  font-size: 1em;
  letter-spacing: 3px;
  font-weight: bold;
  margin: 0;
  padding: 0;

}

figure.card .links li {
  -webkit-transform: translateX(-40px);
  transform: translateX(-40px);
  opacity: 0;
  list-style: none;
}

figure.card a {
  padding: 2px 0;
  display: block;
  color: #ffffff;
  text-decoration: none;
}

figure.card a:hover {
  color: #ffef00;
}

figure.card:hover:after,
figure.card.hover:after {
  -webkit-transform: skew(20deg) translateX(0%);
  transform: skew(20deg) translateX(0%);
}

figure.card:hover img,
figure.card.hover img {
  zoom: 1;
  filter: alpha(opacity=50);
  -webkit-opacity: 0.5;
  opacity: 0.5;
}

figure.card:hover li,
figure.card.hover li {
  opacity: 1;
  -webkit-transform: translateX(0px);
  transform: translateX(0px);
}

figure.card:hover li:first-child,
figure.card.hover li:first-child {
  -webkit-transition-delay: 0.1s;
  transition-delay: 0.1s;
}

figure.card:hover li:nth-child(2),
figure.card.hover li:nth-child(2) {
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

figure.card:hover li:nth-child(3),
figure.card.hover li:nth-child(3) {
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}

figure.card:hover li:nth-child(4),
figure.card.hover li:nth-child(4) {
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}

Combinando as Duas 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.009 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