Hover CSS: aplicando efeito de foco a elemento selecionado!

O hover CSS faz parte do conjunto de palavras-chave utilizadas pelas pseudo-classes da linguagem de estilos e serve para adicionar características a um elemento quando a pessoa usuária posiciona o mouse sobre ele. 

Trata-se de um recurso muito utilizado para adicionar diversas funcionalidades em aplicações web, entre elas para construir menus suspensos, alterar as cores dos elementos e muito mais. Para demonstrar o que é possível fazer com esse recurso, preparamos este post que contém os seguintes tópicos:

  • O que é a pseudo-classe hover CSS? 
  • Qual a sua sintaxe?
  • Exemplos de uso da pseudo-classe hover!   
  • Qual a compatibilidade com os navegadores?

Continue com a gente e boa leitura!

O que é a pseudo-classe hover CSS? 

Antes de falarmos sobre o efeito hover, é importante entender o que são pseudo-classes. Na prática, elas permitem adicionar características a um elemento quando ocorre um determinado evento, como quando clicamos em um link e a cor do texto é modificada em função disso ou quando atribuímos o focus a um determinado item da página HTML.

O hover, portanto, é uma pseudo-classe que identifica quando o mouse está sobre um elemento e modifica as suas características conforme as atribuições indicadas no código CSS para essa condição.

Qual a sua sintaxe?

Basicamente, devemos utilizar a palavra hover após a indicação do seletor, que pode ser um elemento, uma classe ou a identificação, que corresponde ao ID do elemento. Veja a sintaxe:

seletor:hover {
/* definição das propriedades */
}

Exemplo:

h1:hover {
     color: #fff;
     background-color: green;
}

Nesse caso, quando o mouse passar sobre o elemento <h1>, a cor da fonte será modificada para branco e a cor de fundo para verde.

Exemplos de uso da pseudo-classe hover!   

Nada melhor que a visualização de exemplos práticos para entender como esse recurso funciona. Confira alguns códigos que utilizam o efeito hover, a seguir.

Criando uma galeria com imagens full-size e previews!

No exemplo abaixo, vamos construir uma galeria de imagens em que, ao posicionarmos o mouse sobre uma delas, ela será ampliada na escala de 1.5, o que permite visualizá-la em um tamanho maior. Perceba que criamos uma classe chamada .imagem-responsiva, que permite redimensionar a imagem para que ela não fique distorcida, seja qual for o tamanho da tela do dispositivo.

Na classe .box, indicamos as características do espaço destinado às imagens. Perceba que utilizamos a propriedade transition CSS hover, que faz com que o efeito image hover CSS seja realizado com mais suavidade. Dessa forma, ele fica mais elegante e é melhor percebido pela pessoa usuária da aplicação. Confira o código fonte abaixo:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Galeria de imagens com efeito hover</title>
    <style>
        body{
            background-color:rgb(228, 241, 245);
        }
        .container{
            width: 90%;
            height: auto;
            display:flex;     
            flex-wrap: wrap;
            align-items: center;
            justify-content: center;
            margin-top:100px;
        }
        .imagem-responsiva {
            width: 100%;
            height: auto;
        } 
        .box{
            color: #fff;
            width:150px;
            height:150px;
            border: 2px solid white;
            background-color: black;
            box-shadow: 0 2px 2px rgba(0,0,0,0.35);
            transition: transform 0.6s ease-in-out;  
            transition: box-shadow 0.2s ease-in-out;
        }
        .box:hover {
            border: 10px solid black;
            transform: scale(1.5); 
            box-shadow: 0 5px 15px rgba(0,0,0,0.6);
        }
    </style>
</head>
<body>
<div class="container">
    <div class="box">
        <img src="./imagens/imagem01.jpg" class="imagem-responsiva" alt="Imagem 01">
    </div>
    <div class="box">
        <img src="./imagens/imagem02.jpg" class="imagem-responsiva" alt="Imagem 02">
    </div>
    <div class="box">
        <img src="./imagens/imagem03.jpg" class="imagem-responsiva" alt="Imagem 03">
    </div>
    <div class="box">
        <img src="./imagens/imagem04.jpg" class="imagem-responsiva" alt="Imagem 04">
    </div>
    <div class="box">
        <img src="./imagens/imagem05.jpg" class="imagem-responsiva" alt="Imagem 05">
    </div>
    <div class="box">
        <img src="./imagens/imagem06.jpg" class="imagem-responsiva" alt="Imagem 06">
    </div>
</div>
</body>
</html>

Criando um menu dropdown com hover CSS!

No código abaixo, criamos um menu dropdown em que, ao passarmos o mouse sobre cada opção, é aberta a lista suspensa com os itens relacionados. Perceba que utilizamos a pseudo-classe hover várias vezes no código. Na declaração .menu-dropdown .md-item:hover, modificamos a cor do background para criarmos um efeito de luminosidade no item correspondente.

Para que a lista suspensa fique escondida, utilizamos a classe .submenu-dropdown e definimos a propriedade display como none. Também modificamos a cor do background na classe .menu-dropdown .md-item:hover .submenu-dropdown, assim como mostramos o dropdown que estava escondido ao definirmos o display como flex.

Por fim, criamos outro efeito hover sobre os itens do submenu para modificar a cor de fundo para cinza sempre que o mouse for posicionado sobre os itens.

<!DOCTYPE html>
<html lang="pt-br">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Menu dropdown com efeito hover</title>
    <style>
.menubar{  
    width: 90%;
    padding:16px;
    background-color: gray;
    display: flex;
        margin:0 auto;
}
.menu-dropdown {   
    display: flex;
    align-items: center;
    margin: 0;
    list-style-type: none;
}
.menu-dropdown .md-item{  
    position: relative;   
}
.menu-dropdown .md-item:hover{ /* efeito hover nos itens do menu principal */
    background-color:black;
}
.menu-dropdown .md-item a{
    color: #fff; 
    padding:16px;
    text-decoration: none;
    display: flex;
}
.menu-dropdown .md-item a:hover{ /* efeito hover nos links do menu principal */
    background-color: black;
}
.submenu-dropdown{
    display: none; /* esconde o submenu dropdown */
    position: absolute;
    width:100%;  
}
.sd-item:hover .submenu-dropdown{
    display: flex;  
}
.submenu-dropdown .sd-item{
    position: absolute;
    display: flex;
    flex-direction: column;
    left: 0;
    top: 100%;
    width: 100%;
 }
.submenu-dropdown .sd-item a{
    width:100%;
    padding:16px;
    background-color: black;
    color: #fff; 
}
.submenu-dropdown .sd-item a:hover { /* efeito hover nos itens do submenu dropdown */
    background-color: gray;
}
.menu-dropdown .md-item:hover .submenu-dropdown{   /*efeito hover para alterar a cor de fundo*/
    background-color: black; 
    display: flex; /* exibir o submenu dropdown */
}
</style>
</head>
<body>
    <div class="menubar">
        <ul class="menu-dropdown">
            <li class="md-item">
                <a href="">Opção 1</a>
                <ul class="submenu-dropdown">
                    <li class="sd-item">
                        <a href="">Opção 1a</a>
                        <a href="">Opção 1b</a>
                        <a href="">Opção 1c</a>
                    </li>
                </ul>
            </li>
            <li class="md-item">
                <a href="" class="menu-dropdown-item-link">Opção 2</a>
                <ul class="submenu-dropdown">
                    <li class="sd-item">
                        <a href="">Opção 2a</a>
                        <a href="">Opção 2b</a>
                        <a href="">Opção 2c</a>
                    </li>
                </ul>
            </li> 
            <li class="md-item">
                <a href="" class="menu-dropdown-item-link">Opção 3</a>
                <ul class="submenu-dropdown">
                    <li class="sd-item">
                        <a href="">Opção 3a</a>
                        <a href="">Opção 3b</a>
                        <a href="">Opção 3c</a>
                    </li>
                </ul>
            </li>
        </ul>
    </div>
</body>
</html>

Efeitos em links usando hover CSS!

Um dos efeitos utilizados em aplicações web é a mudança da cor do texto em um link ao passarmos o mouse sobre ele. Entretanto, podemos criar diferentes tipos de CSS hover effects com essa pseudo-classe.

No código abaixo, modificamos o tamanho e o formato da fonte para obter um maior destaque para o link e utilizamos a propriedade transition para realizar a transformação de forma gradual e ter o efeito de CSS hover animation,

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Efeito Link hover</title>
    <link href='https://fonts.googleapis.com/css?family=Archivo Black' rel='stylesheet'>
    <style>
    body {
        align-items: center;
        display: flex;
        font-family: 'Archivo Black';
        font-size: 2em;
        height: 100vh;
        background-color:rgb(251, 242, 229);
    }
    .container{
        width: 90%;
        margin: 0 auto;
    }
    .texto{
        text-align: center;
    }
    a {
        color: darkgreen;
        text-decoration: underline;
        transition: all .6s ;
    }
    a:hover {
        font-size:1.2em;
        color: white;
        text-decoration: none;
        -webkit-text-stroke: 2px darkgreen; 
        transition-timing-function: ease-in-out;
}
</style>
</head>
<body>
    <div class="container">
        <p class="texto">Quer aprender HTML?</p>
        <p class="texto"> Temos um <a href="https://blog.betrybe.com/html/">tutorial completo sobre o assunto!</a></p>
    </div>  
</body>
</html>

Qual a compatibilidade com os navegadores?

Sempre que vamos desenvolver uma página HTML, é importante observar se os recursos utilizados funcionam de maneira adequada nas principais ferramentas. Dessa forma, podemos evitar falhas de utilização que podem comprometer a usabilidade da aplicação. Portanto, confira a partir de qual versão a pseudo-classe hover é suportada nos principais navegadores:

  • Internet Explorer: 6;
  • Edge: 12;
  • Firefox: 2;
  • Chrome: 4;
  • Safari: 3.1;
  • Opera: 10;
  • iOS Safari: 3.2;
  • Android Browser: 2.1;
  • Opera Mobile: 12;
  • Chrome for Android: 89;
  • Firefox for Android: 86;
  • Samsung Internet: 4.

O hover CSS é uma pseudo-classe da linguagem de estilos que permite a criação de diversos efeitos interessantes em uma página HTML. Ele pode ser utilizado em conjunto com outras propriedades, como a transition, para fazer com que a transformação realizada seja mais suave e gradativa. 

Gostou do nosso conteúdo sobre a utilização do efeito hover CSS? Então confira nosso post sobre como aprender a programar em HTML e se destacar no mercado