./adote-um-dev.sh

Nível: n00b_m4st3r

Agenda

  • Flexbox
    • Propriedades
      • flex-direction
      • flex-wrap
      • flex-flow
      • flex-grow
      • flex-shrink
      • flex-basis
      • flex
    • Alinhamento
      • justify e align
      • content, items e self

Antes de mais nada...

  • Pra fechar com chave de ouro, vamos aprender sobre o flexbox e como utilizar ele. Vamos ver muitos pontos em comum que vimos com o grid, mas lembrando que estamos falando de forma unidimensional.

Flexbox

  • Pra fechar com chave de ouro, vamos aprender sobre o flexbox e como utilizar ele. Vamos ver muitos pontos em comum que vimos com o grid, mas lembrando que estamos falando de forma unidimensional.

Propriedades

  • A propriedades no flexbox são divididas em container e items (lembrou do nosso coleguinha grid, né?)
  • Para iniciar o flex, precisamos declarar através do display.
.meu-container {
  display: flex;
}
<div class="meu-container">
  <!-- conteudo -->
</div>

Propriedades de container

  • A lista das propriedades para container:
    • flex-direction;
    • flex-wrap;
    • flex-flow;

Propriedades de items

  • A lista das propriedades para container:
    • flex-grow;
    • flex-shrink;
    • flex-basis;
    • flex;

flex-direction

  • Propriedade de container para falar em qual direção será nosso flex.
.meu-container {
  display: flex;
  flex-direction: row | row-reverse | column | column-reverse
}

flex-wrap

  • Propriedade de container que joga para uma nova linha os items que excedem o espaço do container.
.meu-container {
  display: flex;
  flex-wrap: nowrap | wrap | wrap-reverse
}

flex-flow

  • Propriedade de container que engloba o flex-direciton e flwx-wrap.
.meu-container {
  flex-flow: <flex-direction> <flex-wrap>
}

flex-grow

  • Propriedade de item que define se o mesmo deve crescer, se necessário.
.meu-container {
  display: flex;
}

.meu-item {
  flex-grow: <número>;
}
  • Exemplo: se eu tenho 3 items no meu container e quero que o item do meio ocupe o dobro do espaço deles, ficaria assim:
.meu-item-1 {
  flex-grow: 1;
}

.meu-item-2 {
  flex-grow: 2;
}

.meu-item-3 {
  flex-grow: 1;
}

flex-shrink

  • Propriedade de item que define a capacidade de encolher do item, se necessário.
.meu-container {
  display: flex;
}

.meu-item {
  flex-shrink: <número>;
}

flex-basis

  • Propriedade de item que define o tamanho inicial do item, antes do flexbox distribuir o tamanho para os demais items. É mais complexo e pouco usado
.meu-container {
  display: flex;
}

.meu-item {
  flex-basis: <tamanho> | auto;
}

flex

  • Propriedade de item que engloba o flex-grow, flex-shrink e flex-basis;
.meu-container {
  display: flex;
}

.meu-item {
  flex: none | <flex-grow> <flex-shrink> <flex-basis>
}

Alinhamento

  • Para container:
    • justify-content;
    • align-items;
    • align-content;
  • Para items:
    • align-self

justify-content

  • Define o alinhamento dos items no container, em relação ao eixo principal.
.meu-container {
  justify-content: flex-start | flex-end | center | space-between | space-around | space-evenly;
}

align-items

  • Define o alinhamento dos items no container, em relação ao eixo transversal.
.meu-container {
  align-items: stretch | flex-start | flex-end | center | baseline;
}

align-content

  • Define o alinhamento das linhas, distribuindo melhor os items no espaço do container
.meu-container {
  align-content: flex-start | flex-end | stretch | center | space-between | space-around;
}

align-self

  • Define o alinhamento de um item no container;
.meu-container {
  align-self: auto | stretch | flex-start | flex-end | center | baseline;
}

Conclusão

Fechamos os dois pilares mais importantes para nosso desenvolvimento web. Uma aplicação é composta por HTML, CSS e JavaScript. Já sabemos como criar documentos HTML de forma semântica e agora sabemos como estilizar e alinhar nosso documento para que ele ganhe uma cara nova. A partir de agora, vamos entrar no maior foco dessa jornada que é o JavaScript!

Adote um Dev - Nível n00b_m4st3r: Flexbox

By Pedro Mello

Adote um Dev - Nível n00b_m4st3r: Flexbox

Flexbox

  • 162