Propriedade Float e Clear Estruturando e flutuando elementos

Algo comum ao lermos alguma matéria em revistas ou jornais é uma imagem relacionada ao texto estar posicionada de um lado e, o conteúdo textual contornar a imagem. Algo parecido com isso:
Representação de uma simulação de um layout clássico de revistas e jornais com uma foto do lado esquerdo e texto ao redor dela
E se precisássemos desenvolver um template parecido com a imagem acima. Provavelmente começaríamos com um código HTML assim:
  1. <div>
  2. <figure>
  3. <img src="img/imagem.jpg" alt="Imagem Xis">
  4. <figcaption>Legenda da imagem"</figcaption>
  5. </figure>
  6. <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Eum, fugit, ipsam reprehenderit porro aperiam esse quibusdam ratione excepturi amet est.</p>
  7. <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Eum, fugit, ipsam reprehenderit porro aperiam esse quibusdam ratione excepturi amet est.</p>
  8. <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Eum, fugit, ipsam reprehenderit porro aperiam esse quibusdam ratione excepturi amet est. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Eum, fugit, ipsam reprehenderit porro aperiam esse quibusdam ratione excepturi amet est</p>
  9. </div>
<script async src="https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"></script> <!-- Demostra a noticia com ela é --> <ins class="adsbygoogle" style="display:inline-block;width:970px;height:90px" data-ad-client="ca-pub-9446227258700542" data-ad-slot="8295479456"></ins> <script> (adsbygoogle = window.adsbygoogle || []).push({}); </script>
O que teríamos seria algo assim:
Representação mostrando uma imagem no topo e um bloco de texto abaixo dela
Por que isso? O que acontece é que a tag figure ocupa toda a largura da página e entra no empilhamento do documento/página, o que não permite que outros elementos apareçam ao seu lado.
É aí que entra o float. Em resumo, essa propriedade permite que tiremos um elemento do fluxo vertical da página e automaticamente faz com que o conteúdo que venha a seguir flutue ao seu redor.
CSS ficaria assim:
  1. figure {
  2. float: left;
  3. margin: 0 10px 10px 0;
  4. }
O que fizemos foi flutuar a tag figure para o lado esquerdo e, colocar uma margem inferior e direita para que os parágrafos não fiquem grudados na imagem. Com isso conseguiríamos reproduzir um layout igual ao da primeira imagem. Poderíamos até variar e colocar nossa imagem do lado direito:
  1. figure {
  2. float: right;
  3. margin: 0 0 10px 10px;
  4. }
Aqui mudamos a direção que a tag figure vai flutuar e alteramos a margem do lado direito para o lado esquerdo. E teríamos um resultado assim:
Representação simulando um layout clássico de revistas e jornais com uma foto do lado direito e texto ao redor dela

A propriedade clear

Continuando com o nosso exemplo anterior, imagine que agora precisássemos inserir um novo título com mais parágrafos abaixo da imagem. Algo parecido com isso: (para fins de exemplo, diminui o conteúdo textual ao redor da imagem)
Representação de um layout com imagem localizada no topo esquerdo com parágrafos ao redor dela e um título com mais parágrafos no fluxo da página
Para representar esse conteúdo, teríamos um HTML semelhante a esse:
  1. <div>
  2. <figure>
  3. <img src="img/imagem.jpg" alt="Imagem Xis">
  4. <figcaption>Legenda da imagem"</figcaption>
  5. </figure>
  6. <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Eum, fugit, ipsam reprehenderit porro aperiam esse quibusdam ratione excepturi amet est.</p>
  7. <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Eum, fugit, ipsam reprehenderit porro aperiam esse quibusdam ratione excepturi amet est.</p>
  8. <h3>Novo título</h3>
  9. <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Eum, fugit, ipsam reprehenderit porro aperiam esse quibusdam ratione excepturi amet est.</p>
  10. <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Eum, fugit, ipsam reprehenderit porro aperiam esse quibusdam ratione excepturi amet est.</p>
  11. </div>
No entanto, chegaríamos num resultado assim:
Representação de um layout com imagem localizada no topo esquerdo com conteúdo textual ao redor dela
Por que isso? Como definimos que a tag figure flutuaria à esquerda, saindo assim do fluxo vertical da página, todo conteúdo que vem após ela começa a preencher o espaço ao redor da imagem. O que acontece é que os parágrafos que vem logo após a tag figure são menores que a altura da imagem, fazendo com que o título (tag h3) ao invés de ser renderizada abaixo da imagem, apareça ao lado dela e seguindo o fluxo do documento.
É aí que entra a propriedade clear. Ela tem a função de controlar o comportamento de elementos que apareçam no fluxo do documento após determinado elemento que possue a propriedade float. Em outras palavras, ela especifica se um elemento deve ser posicionado ao lado de elementos com float ou se devem ser colocados abaixo deles. A propriedade aceita 4 valores:
  • left: Elemento é empurrado para baixo de elementos com float left;
  • right: Elemento é empurrado para baixo de elementos com float right;
  • both: Elemento é empurrado para baixo de elementos com float left ou right;
  • none: Elemento não é empurrado para baixo de elementos com float.
CSS ficaria assim:
  1. figure {
  2. float: left;
  3. margin: 0 10px 10px 0;
  4. }
  5.  
  6. h3 { clear: both; }
  7. /* Pelo fato da tag figure utilizar float left, aqui também poderíamos usar clear: left; */
E com isso, conseguiríamos fazer com que o título (tag h3) fosse empurrado para baixo, sendo renderizado abaixo da tag figure e ficando igual ao layout que queríamos.

Mais exemplos

Esse foi apenas um exemplo da utilização da propriedade float. Outros casos que você pode ver em vários websites são:
Menus de navegação
Float usado nos itens da lista. Mais precisamente em cada li, para dispor os itens do menu na horizontal.
Grids
Float usado para dividir partes do grid. Por exemplo, colocar um bloco de conteúdo à esquerda e um outro bloco à direita.

Postagens mais visitadas