./adote-um-dev.sh

Nível: n00b_m4st3r

Agenda

  • Grid
    • Propriedades
      • container
      • items
    • Alinhamento
      • justify e align
      • content, items e self

Antes de mais nada...

  • Agora que já sabemos o básico do funcionamento do CSS, é hora de deixarmos nossos documentos web com um posicionamento e divisões mais interessantes. Hoje, vamos entender o sistema de Grid e conhecer o framework referência para estilização e posicionamento: Bootstrap.

Grid

  • Grid é uma técnica, em CSS, para criação de layouts em uma forma de grade. A grade é composta por linhas e colunas, como uma espécie de tabela
  • Diferente do Flexbox, que trabalha com uma dimensão, no Grid nós trabalhos com duas.

Grid

  • Nosso grid é dividido por duas propriedades principais:
    • Container: é o agrupamento dos nossos grid items, em linhas e colunas;
    • Items: são as células do nosso grid, onde nosso conteúdo está inserido; 

grid item

Grid: how to use

  • Para utilizar o sistema de grid, precisar iniciar essa forma de display, através do nosso código CSS, apontando para um seletor que será nosso container.
.meu-container {
  display: grid;
}
<div class="meu-container">
  <!-- conteúdo do container -->
</div>
  • Agora precisamos indicar quantas linhas e quantas colunas teremos no nosso grid. Nesse caso, 2 colunas e 3 linhas.
.meu-container {
  display: grid;
  grid-template-columns: 3fr 1fr;
  grid-template-rows: 10vh 70vh 20vh;
}

Obs: a unidade "FR" é uma fração e "VH" de view-height

Grid: how to use

  • Vamos montar um template simples, com header, main, aside e footer. Eles ficaram dentro do nosso container e serão nossos items. Para cada item, precisamos definir qual espaço ocuparão no grid.
header {
  background: purple;
  grid-column: 1/3;
}

main {
  background: violet;
  grid-column: 1/2;
}

aside {
  background: black;
  grid-column: 2/3;
}

footer {
  background: yellow;
  grid-column: 1/3;
}
<div class="meu-container">
  <header></header>
  <main></main>
  <aside></aside>
  <footer></footer>
</div>

Grid: how to use

  • "Nossa, que confuso". Sim... é bastante informação, mas temos como simplificar essa brincadeira utilizando o grid-area. Vamos ao mesmo exemplo mas utilizando agora o grid-area:
.meu-container {
  display: grid;
  grid-template-columns: 3fr 1fr;
  grid-template-rows: 10vh 70vh 20vh;
  grid-template-areas: "a a"
                       "b c"
                       "d d"
}
<div class="meu-container">
  <header></header>
  <main></main>
  <aside></aside>
  <footer></footer>
</div>

Grid: how to use

  • E agora utilizando as áreas que criamos para nossos outros elementos:
header {
  background: purple;
  grid-area: a;
}

main {
  background: violet;
  grid-area: b;
}

aside {
  background: black;
  grid-area: c;
}

footer {
  background: yellow;
  grid-area: d;
}
<div class="meu-container">
  <header></header>
  <main></main>
  <aside></aside>
  <footer></footer>
</div>

Grid: how to use

  • Mensão honrosa: grid-gap
.meu-container {
  display: grid;
  grid-template-columns: 3fr 1fr;
  grid-template-rows: 10vh 70vh 20vh;
  grid-template-areas:
    "a a"
    "b c"
    "d d";
    
  grid-gap: 5px;
}

Alinhamento

  • No grid, estamos trabalhando com duas dimensões, ou seja, 2 eixos: X e Y.
  • O eixo X, é nosso eixo horizontal, que vai da esquerda para a direita.
    • justify
  • O eixo Y, é nosso eixo vertical, que vai de cima para baixo.
    • align

Justify & Align - Content

  • Com a propriedade justify-content e align-content, nós estamos alterando o alinhamento do container do grid.

Justify & Align - Items

  • Com a propriedade justify-items e align-items, nós estamos alterando o alinhamento dos items que estão dentro do container do grid.

Justify & Align - Self

  • De forma muito semelhante ao anterior, justify-self e align-self também altera o posicionamento dos items do container do grid, mas dessa vez o CSS é aplicado diretamente no item que queremos, e não no container.

Conclusão

Hoje nós aprendemos a mexer com o display Grid do CSS e vimos as formas de alinhamento, utilizando eixo X e eixo Y com as propriedades content, items e self. Com isso, já podemos criar nossos layouts baseados em grid e avançar para o próximo nível.

Adote um Dev - Nível n00b_m4st3r: Grid

By Pedro Mello

Adote um Dev - Nível n00b_m4st3r: Grid

Grid

  • 159