DEV Community

diogomiaguy
diogomiaguy

Posted on

# Estudos sobre FLEXBOX

Link dos videos que gravei enquanto estudava: https://www.youtube.com/playlist?list=PLJa9e-ROBLypvJvZvy3o6fXgT2yxunuqn

Flexbox é destinado à criação de layout em uma dimensão, horizontal ou vertical.

Flex container é um elemento de marcação contendo elementos filhos e destinado a criar um contexto de formatação flex para este elementos filhos.

Vamos utilizar a seguinte estrutura HTML para nossos exemplos:

<div class="container">
  <div class="item">item-1</div>
  <div class="item">item-2</div>
  <div class="item">item-3</div>
</div>
Enter fullscreen mode Exit fullscreen mode

Nosso CSS base vai ser:

* {
  margin: 0;
  padding: 0;
}
/* Flex Container */
.container {
  max-width: 600px;
  margin: 20px auto;
/* esquemas flexbox */
}
/* Flex items*/
.item {padding: 10px 0;text-align: center;}
.container> :nth-child(1){
  background: cadetblue;
}
.container> :nth-child(2){
  background: red;
}
.container> :nth-child(3){
  background: yellowgreen;
}
Enter fullscreen mode Exit fullscreen mode

Propriedade Display

A propriedade display foi criada em 1996 pela especificação para a CSS1 e só permitia os valores none, block, inline e list-item. Agora podemos usar o valor flex. 
Quando definimos um elemento pai com o display flex ele se torna um container Flex e todos os seus 'filhos' passam a ser denominados como flex itens. 
Utilização: display: flex;

Por padrão o display flex, definido no pai, tem seu flex-direction como row, ou seja, em linha.

Propriedade Direction

Destinado a definir o sentido e a direção do eixo principal. Podemos alterar essa direção indicando com as seguintes opções:

flex-direction: column; //deixa a direção do eixo em coluna
flex-direction: column-reverse; //deixa a direção do eixo em coluna reversa
flex-direction: row-reverse; //deixa a direção do eixo em linha reversa
flex-direction: row; //deixa a direção do eixo em linha
Enter fullscreen mode Exit fullscreen mode

Propriedade Wrap

O flex-wrap é utilizado quando queremos que haja a quebra de linha dos flex itens. Isso serve para que eles não fiquem compactados além do limite do seu conteúdo. Nele temos as seguinte opções:

 

flex-wrap: nowrap;//não deixa haver a quebra de linha
flex-wrap: wrap;//habilita a quebra de linha
flex-wrap: wrap-reverse;//habilita a quebra de linha reversa
Enter fullscreen mode Exit fullscreen mode

Propriedade Flow

O flex-flow é um atalho para usar o flex-direction e flex-wrap. Nele temos as seguintes opções:

flex-flow: row nowrap; //define o flex-direction como inline e sem quebra de linha
flex-flow: row wrap; //define o flex-direction como inline e com quebra de linha
flex-flow: column nowrap; //define o flex-direction como em coluna e sem quebra de linha
Enter fullscreen mode Exit fullscreen mode

Propriedade Justify-content

Justify-content é usado no flex container para alinhar os filhos em determinada direção para ocupar todo o conteúdo do seu container, isso se já não estiverem ocupando o espaço. Nele temos as seguintes opções:

justify-content: space-around; 
justify-content: space-between; 
justify-content: center; 
justify-content: flex-end; 
justify-content: flex-start;
Enter fullscreen mode Exit fullscreen mode

Propriedade align-itens

Utilizamos o align-items para fazer um alinhamentos dos filhos em relação ao eixo do container pai. Nele temos as seguintes opções:

 

align-items: baseline; 
align-items: center; 
align-items: flex-end; 
align-items: flex-start; 
align-items: stretch;
Enter fullscreen mode Exit fullscreen mode

Propriedade align-content

Para utilizar o align-content precisamos que o container flex (pai) tenha um heigth definido e que esse valor tem que ser maior que a soma das linhas dos filhos. Use o wrap pelo amor de Deus.

AGORA SOBRE OS ITENS

Propriedade grow

Destinado a definir o fator de crescimento do flex item dentro do container quando nele há espaço disponível. 
Pega o espaço restante e divide pelo valor do grow definido no item.
Como usar:

flex-grow: N;(definir um numero)
Enter fullscreen mode Exit fullscreen mode

Propriedade shrink

Destinado a definir o fator de encolhimento do flex item dentro do container quando a largura do container for menor do que a soma das larguras dos flex items. Nele temos as seguintes opções:

 

flex-shrink: 1; 
flex-shrink: 0; 
flex-shrink: número;
Enter fullscreen mode Exit fullscreen mode

Propriedade Basis

Destinado a definir a dimensão inicial do flex item dentro do container, nos sentidos largura ou altura. Indica o tamanho inicial do flex item ANTES da distribuição do espaço restante. Nele temos as seguintes opções:

 

flex-basis: auto;
flex-basis: unidade;
flex-basis: 0;
Enter fullscreen mode Exit fullscreen mode

Propriedade flex

Propriedade que é a forma abreviada de se declarar as propriedades flex-grow, flex-shrink e flex-basis de uma só vez. O único valor obrigatório dessa propriedade é o flex-basis. O valor inicial dessa propriedade é 1 0 auto. É recomendado utilizar a propriedade flex ao invés de cada propriedade separada. Utilização:

 

flex: 1; // Define flex-grow: 1; flex-shrink: 1; e flex-basis: 0; 
flex: 0 1 auto; // Esse é o padrão,
flex: 2; // Define exatamente da mesma forma que o flex: 1; porém neste caso o flex-grow será de 2, o flex-shrink continuará 1 e o flex-basis 0.
flex: 3 2 300px; // flex-grow: 3, flex-shrink: 2 e flex-basis: 300px;
Enter fullscreen mode Exit fullscreen mode

Propriedade order

Destinado a reordenar os flex itens dentro do container pai sem zuar a ordem que eles ocupam na marcação. Seu valor inicial é zero. Como usar:

 

order: N ; (definir um numero)
Enter fullscreen mode Exit fullscreen mode

Propriedade align-self

Destinado ao alinhamento individual dos flex itens dentro do container pai e segundo a direção e sentido eixo. Esse alinhamento acontece tanto em linha como em coluna. Nele temos as seguintes opções:

 

align-self: stretch;
align-self: baseline; //alinha conforme a tipografia
align-self: center; //alinha no centro
align-self: flex-end; //alinha ao final
align-self: flex-start; //alinha no inicio
align-self: auto;
Enter fullscreen mode Exit fullscreen mode

Top comments (0)