O document flow(fluxo do documento), é a maneira como os elementos HTML são apresentados na tela do computador ou dispositivo mobile, ou melhor dizendo, como eles são RENDERIZADOS no navegador.
Antes de sabermos como isso funciona, devemos primeiro saber que a maioria dos elementos no HTML são classificados em dois grupos:
* Elementos Block-level.
* Elementos Inline.
Os elementos block-level são aqueles que, assim que colocados no documento, mandam para baixo os elementos posteriores a ele(calma, vou explicar melhor).
Abaixo segue a lista de todos os elementos block-level:
<address>
<article>
<aside>
<audio>
<blockquote>
<canvas>
<dd>
<div>
<dl>
<fieldset>
<figcaption>
<figure>
<footer>
<form>
<h1>, <h2>, <h3>, <h4>, <h5>, <h6>
<header>
<hgroup>
<hr>
<noscript>
<ol>
<output>
<p>
<pre>
<section>
<table>
<tfoot>
<ul>
<video>
Vou mostrar um exemplo usando a tag <div></div>:
Neste exemplo há dois elementos block-level: <h3> e <div>, observe que a <div> está abaixo do texto(<h3>), este é o código para gerar este documento:
<!DOCTYPE html>
<html>
<body>
<h3>Texto sendo apresentado tranquilamente =) </h3>
<div style="width:80px;height:80px;background-color:pink;">Div quietinha</div>
</body>
</html>
Veja agora o que acontece se colocarmos a <div> em cima do <h3>:
A <div> sendo um elemento block-level, empurra os demais elementos para baixo dela. Repare que embora caibam os dois elementos, o texto e a div, ela ainda assim, empurra-o para baixo.
Abaixo tem uma lista com alguns elementos inline:
<em>
<strong>
<a>
<abbr>
<dfn>
<code>
<samp>
<kbd>
<var>
<b>
<i>
<u>
<small>
<s>
<span>
<br>(ele força uma quebra de linha, mas em si, é um elemento inline)
<bdo>
<cite>
<del>
<ins>
<q>
<script>
<sub>
<wbr>
<area>
<img>
<map>
<object>
<param>...
...E muitos outros (pesquisem aqui: http://en.wikipedia.org/wiki/HTML_element#Inline_elements).
Agora veja o que acontece quando a gente coloca um elemento inline após outro:
O código que gera esse resultado:
<!DOCTYPE html>
<html>
<body>
<em>Texto com ênfase!</em>
<span style="background-color:pink;">span simples</span>
</body>
</html>
Note que o elemento <em> é amiguinho do <span>, ele não empurra o <span> para baixo, mas sim, permite que ele fique ao seu lado. É exatamente essa a diferença entre os elementos do tipo block-level e os elementos inline: os block-level empurram o próximo elemento para baixo, enquanto os inline mantém o próximo elemento à direita.
2- PROPRIEDADE POSITION:
Para posisionar um elemento HTML de uma forma especial, usamos o position. Posicionar... position... sacou? Dexa prá lá.
O position é uma propriedade CSS muito útil caso você precise alterar o document flow (exemplo acima).
Existem 3 tipos de position:
*Position Fixed
*Position Relative
*Position Absolute
Position Fixed:
Fixa o elemento(jura?) ao documento nas coordenadas que você definir, com ele mesmo que a página role, o elemento fica parado onde sempre esteve.
Mas como usar essa propriedade? Abaixo temos um exemplo:
<!DOCTYPE html>
<html>
<body>
<div style=
"width:100px;height:100px;background-color:pink;
left:200px;
top:50px;
position:fixed;">Daqui não saio<br>daqui ninguém me tira!</div>
<p>
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo exemplo exemplo
exemplo exemplo exemplo exemplo exemplo exemplo
</p>
</body>
</html>
Mesmo a <div> sendo um elemento block-level, ela não empurra o <p>, que também é um elemento block-level, ficando fixa na posição: left:200px; e top:50px;
Outra coisa: ao se usar o position, a posição(ou coordenada) é definida a partir da ponta esquerda de cima, no caso do position fixed: o navegador calcula as coordenadas partindo da ponta esquerda de cima, da tela.
Position Relative:
Posiciona o elemento em relação a si mesmo, o ponto zero(de onde começa o cálculo para as coordenadas), é o canto superior esquerdo, a partir daí o navegador acrescentará os píxels.
Position Absolute:
Trabalha quase da mesma maneira que o position relative, porém ele é utilizado para posicionar elementos dentro de outros elementos, ou seja, calcula as coordenadas em relação ao elemento pai.
Exemplo:
E o seu código:
<!DOCTYPE html>
<html>
<body>
<div style="width:300px;height:300px;background-color:gray; ">
<div style=
"width:100px;height:100px;background-color:pink;
left:50px;
top:50px;
position:absolut;">Absolute
</div>
</div>
</body>
</html>
3- PROPRIEDADE FLOAT:
A propriedade float do CSS, também permite alterar o document flow.
Existem dois atributos que podemos colocar em float:
*left
*right
Veja um exemplo usando o float:left;
e o código:
<!DOCTYPE html>
<html>
<body>
<div style="width:300px;height:300px;background-color:gray;">
<div style="width:100px;height:100px;background-
color:pink;float:left;">esquerda</div>
</div>
</body>
</html>
No caso acima, a div rosa ficou à esquerda dentro da div cinza.
Agora veja se usarmos o float:right;
Viu só? A div agora foi para a direita, o que não é padrão(por padrão os elementos vão de cima para baixo, e da esquerda para a direita, como na leitura).
a) Clear:
A propriedade clear especifica quais os lados de um elemento onde outros elementos flutuantes não são permitidos. Por exemplo: se você não quer que os elementos flutuem para a direita dentro de um elemento <p> por exemplo, basta usar(no css):
p.clear{
clear:right;
}
Para limpar a esquerda:
p.clear{
clear:left;
}
E para limpar ambos os lados:
p.clear{
clear:both;
}
b) Problemas de Pushdown e possíveis soluções:
Pushdowns são problemas que ocorrem quando um ou mais elementos não cabem dentro de outro e, dessa forma, empurram todos os outros elementos para baixo deixando a maior confusão no layout da página.
Abaixo mostro um exemplo bem simples de pushdown:
Veja a bagunça.
Agora vamos estudar o código:
<!DOCTYPE html>
<html>
<body>
<div style="width:300px;height:300px;background-color:gray;">
<div style="width:150px;height:150px;background-color:pink;float:left;">div 1</div>
<div style="width:160px;height:160px;background-color:pink;float:left;">Não coube =(</div>
</div>
</body>
</html>
As duas divs rosas estão dentro de outra div, essa div(a maior), tem 300 píxels de width.
A div 1 tem 150 píxels de width, e a outra tem 160 píxels, ou seja não cabem as duas juntas, uma ao lado da outra, sendo assim a div que não coube foi para baixo, e se tivessem outros elementos depois dela eles seriam empurrados também.
Mas o que fazer então caso isso ocorra?
Simples: preste atenção aos tamanhos de largura, e nunca defina uma altura em um elemento pai(aquele que receberá outros elementos, esses sim podem ter altura). Outra coisa a se fazer é colocar a propriedade position absolute, mas lembre-se: o position absolute tira o elemento do fluxo do documento(document flow), portanto tenha cuidado.
I) Falso posicionamento absoluto:
Isto serve para trabalhar com colunas e linhas(e os elementos que estão dentro delas) de forma que se ajuste à tela sem que haja problemas como push-down etc.
Esse método é feito usando uma combinação de position: relative , à esquerda: 100% e um negativo da margin esquerda .
O CSS aplicados a estes elementos é o seguinte:
.Linha {
float: left;
width: 100%;
display: block;
position: relative;
}
b) Problemas de Pushdown e possíveis soluções:
Pushdowns são problemas que ocorrem quando um ou mais elementos não cabem dentro de outro e, dessa forma, empurram todos os outros elementos para baixo deixando a maior confusão no layout da página.
Abaixo mostro um exemplo bem simples de pushdown:
Veja a bagunça.
Agora vamos estudar o código:
<!DOCTYPE html>
<html>
<body>
<div style="width:300px;height:300px;background-color:gray;">
<div style="width:150px;height:150px;background-color:pink;float:left;">div 1</div>
<div style="width:160px;height:160px;background-color:pink;float:left;">Não coube =(</div>
</div>
</body>
</html>
As duas divs rosas estão dentro de outra div, essa div(a maior), tem 300 píxels de width.
A div 1 tem 150 píxels de width, e a outra tem 160 píxels, ou seja não cabem as duas juntas, uma ao lado da outra, sendo assim a div que não coube foi para baixo, e se tivessem outros elementos depois dela eles seriam empurrados também.
Mas o que fazer então caso isso ocorra?
Simples: preste atenção aos tamanhos de largura, e nunca defina uma altura em um elemento pai(aquele que receberá outros elementos, esses sim podem ter altura). Outra coisa a se fazer é colocar a propriedade position absolute, mas lembre-se: o position absolute tira o elemento do fluxo do documento(document flow), portanto tenha cuidado.
I) Falso posicionamento absoluto:
Isto serve para trabalhar com colunas e linhas(e os elementos que estão dentro delas) de forma que se ajuste à tela sem que haja problemas como push-down etc.
Esse método é feito usando uma combinação de position: relative , à esquerda: 100% e um negativo da margin esquerda .
O CSS aplicados a estes elementos é o seguinte:
.Linha {
float: left;
width: 100%;
display: block;
position: relative;
}
.Item {
position: relative;
float: left;
left: 100%;
}
Para posicionar um determinado item, tudo o que precisamos de fazer é dar uma margem esquerda negativa e uma largura . Por exemplo:
position: relative;
float: left;
left: 100%;
}
Para posicionar um determinado item, tudo o que precisamos de fazer é dar uma margem esquerda negativa e uma largura . Por exemplo:
margin-left: -100%;
width: 30%;
}
c) PROBLEMAS CROSSBROWSER E POSSÍVEIS SOLUÇÕES:
Com a grande quantidade de navegadores existentes no mercado, acontecem alguns errinhos na renderização que causam um certo transtorno ao desenvolvedor, pois o que funciona em alguns navegadores pode não funcionar em outros, ou as vezes funciona em todos e deixa de funcionar em apenas um deles...(estou falando de vc, IE....brincadeira).
Mas há uma luz no fim do túnel!(tomara que não seja um trem vindo daquela direção).
Para sanar esses erros, ou pelo menos diminuí-los, basta prestar bastante atenção quanto aos itens abaixo:
2) Trabalhe em cima das Web Standards(padrões web, ou seja, W3C)
3) Faça testes em diversos navegadores
4) Realize os testes primeiro em navegadores modernos
d)TEMPLATE LAYOUT:
A propriedade float é muito simples de se entender. O problema não é o funcionamento, mas os efeitos que a propriedade float causa nos elementos próximos. Se você pede para duas colunas ficarem flutuando à esquerda e outra coluna à direita, o rodapé sobe. Ou se você coloca um elemento envolvendo outros elementos com float, esse elemento perde a altura. Estes são problemas corriqueiros que já tem soluções inteligentes e que não apresentam chateações mais graves.
Infelizmente o float não é o ideal para a diagramação e organização dos elementos do layout. Ele resolve muitos problemas, mas deixa a desejar em diversos sentidos. O float está completamente ligado a ordem dos elementos no HTML. Existem técnicas que você consegue fazer quase que qualquer organização visual sem encostar no código HTML. Mas há outras necessidades que invariavelmente você precisará modificar a ordem dos elementos no meio do HTML para que a diagramação do site saia conforme o esperado. Essa organização do HTML pode alterar desde programação server-side e até resultados de SEO e acessibilidade. Por isso é interessante que o HTML fique organizado de forma que ele supre as necessidades dessas bases. Sua organização visual deve ser independente desta organização.
I) TEMPLATE-BASED POSITIONING:
A propriedade float é muito simples de se entender. O problema não é o funcionamento, mas os efeitos que a propriedade float causa nos elementos próximos. Se você pede para duas colunas ficarem flutuando à esquerda e outra coluna à direita, o rodapé sobe. Ou se você coloca um elemento envolvendo outros elementos com float, esse elemento perde a altura. Estes são problemas corriqueiros que já tem soluções inteligentes e que não apresentam chateações mais graves.
Infelizmente o float não é o ideal para a diagramação e organização dos elementos do layout. Ele resolve muitos problemas, mas deixa a desejar em diversos sentidos. O float está completamente ligado a ordem dos elementos no HTML. Existem técnicas que você consegue fazer quase que qualquer organização visual sem encostar no código HTML. Mas há outras necessidades que invariavelmente você precisará modificar a ordem dos elementos no meio do HTML para que a diagramação do site saia conforme o esperado. Essa organização do HTML pode alterar desde programação server-side e até resultados de SEO e acessibilidade. Por isso é interessante que o HTML fique organizado de forma que ele supre as necessidades dessas bases. Sua organização visual deve ser independente desta organização.
I) TEMPLATE-BASED POSITIONING:
Tendo em vista estes e outros problemas o W3C criou um novo módulo. Na verdade ele não é o único, e nem pode ser para que tenhamos diversas formas de trabalhar. O módulo em questão é chamado de Template Layout. Esse módulo consiste em uma forma de criarmos e organizarmos os elementos e informações do layout de forma menos espartana e mais flexível.
Podemos dividir a construção do layout em duas grandes partes: 1) Definição dos elementos mestres e grid a ser seguido. 2) Formatação de font, cores, background, bordas etc.
As propriedades nesta especificação trabalham associando uma política de layout de um elemento. Essa política é chamada de template-based positioning (não tem nada a ver com a propriedade position, pelo contrário é uma alternativa) que dá ao elemento uma grid invisível para alinhar seus elementos descendentes.
Porque o layout deve se adaptar em diferentes janelas e tamanhos de papéis, as colunas e linhas do grid deve ser fixas ou flexiveis dependendo do tamanho.
O W3C mostra alguns casos comuns:
· Páginas complexas com múltiplas barras de navegação em áreas com posições fixas como publicidade, submenus e etc.
· Formulários complexos, onde o alinhamento de labels e campos podem ser facilmente definidos com as propriedades deste módulo com a ajuda das propriedades de margin, padding e tables.
· GUIs, onde botões, toolbars, labels, ícones etc, tem alinhamentos complexos e precisam estar sempre alinhados caso o tamanho ou a resolução da tela mudam.
· Medias que são paginadas, como medias de impressão onde cada página são divididos em áreas fixas para conteúdos de gêneros diferentes.
Template-based positioning são uma alternativa para a propriedade position com o valor absolute. Antigamente lembro-me que quase todos os desenvolvedores tentavam organizar e diagramar layouts utilizando position. Não que seja errado, mas definitivamente não é a melhor forma. Costumo dizer em meus cursos e palestras que position é para detalhes. Nada muito grande, mas para pequenos detalhes. Usamos position para posicionarmos elementos que não tem relação direta com sua posição no código HTML. Ou seja, não importa onde o elemento esteja, o position:absolute; irá posicionar o elemento nas coordenadas que você quiser.
Sintaxe e funcionamento
O módulo Template Layout basicamente define slots de layout para que você encaixe e posicione seus elementos. O mapeamento dos slots é feito com duas propriedades que já conhecemos que este módulo adiciona mais alguns valores e funcionalidades, são as propriedades position e display.
A propriedade display define como será o Grid, ou seja, quantos espaços úteis terá o layout.
A propriedade position irá posicionar seus elementos nestes slots.
Veja o código HTML abaixo:
Podemos dividir a construção do layout em duas grandes partes: 1) Definição dos elementos mestres e grid a ser seguido. 2) Formatação de font, cores, background, bordas etc.
As propriedades nesta especificação trabalham associando uma política de layout de um elemento. Essa política é chamada de template-based positioning (não tem nada a ver com a propriedade position, pelo contrário é uma alternativa) que dá ao elemento uma grid invisível para alinhar seus elementos descendentes.
Porque o layout deve se adaptar em diferentes janelas e tamanhos de papéis, as colunas e linhas do grid deve ser fixas ou flexiveis dependendo do tamanho.
O W3C mostra alguns casos comuns:
· Páginas complexas com múltiplas barras de navegação em áreas com posições fixas como publicidade, submenus e etc.
· Formulários complexos, onde o alinhamento de labels e campos podem ser facilmente definidos com as propriedades deste módulo com a ajuda das propriedades de margin, padding e tables.
· GUIs, onde botões, toolbars, labels, ícones etc, tem alinhamentos complexos e precisam estar sempre alinhados caso o tamanho ou a resolução da tela mudam.
· Medias que são paginadas, como medias de impressão onde cada página são divididos em áreas fixas para conteúdos de gêneros diferentes.
Template-based positioning são uma alternativa para a propriedade position com o valor absolute. Antigamente lembro-me que quase todos os desenvolvedores tentavam organizar e diagramar layouts utilizando position. Não que seja errado, mas definitivamente não é a melhor forma. Costumo dizer em meus cursos e palestras que position é para detalhes. Nada muito grande, mas para pequenos detalhes. Usamos position para posicionarmos elementos que não tem relação direta com sua posição no código HTML. Ou seja, não importa onde o elemento esteja, o position:absolute; irá posicionar o elemento nas coordenadas que você quiser.
Sintaxe e funcionamento
O módulo Template Layout basicamente define slots de layout para que você encaixe e posicione seus elementos. O mapeamento dos slots é feito com duas propriedades que já conhecemos que este módulo adiciona mais alguns valores e funcionalidades, são as propriedades position e display.
A propriedade display define como será o Grid, ou seja, quantos espaços úteis terá o layout.
A propriedade position irá posicionar seus elementos nestes slots.
Veja o código HTML abaixo:
<div class=”geral”>
<nav class=”menu”>...</nav>
<aside class=”menulateral”>...</aside>
<aside class=”publicidade”>...</aside>
<article class=”post”>...</article>
<footer>...</footer>
</div>
Agora vamos definir a posição destes elementos.
O código CSS seria assim:
.geral {
display: “aaa”
“bcd”
“eee”;
}
nav.menu {position:a;}
aside.menulateral {position:b;}
aside.publicidade {position:d;}
article.post {position:c;}
footer {position:e;}
Puro gesso! (Lê-se puro gessó)
Logo menos traremos mais postagens aguardemmm...
.geral {
display: “aaa”
“bcd”
“eee”;
}
nav.menu {position:a;}
aside.menulateral {position:b;}
aside.publicidade {position:d;}
article.post {position:c;}
footer {position:e;}
Puro gesso! (Lê-se puro gessó)
Logo menos traremos mais postagens aguardemmm...
=D