Centrado en la cuadrícula CSS


Estoy tratando de crear una página simple con Cuadrícula CSS.

Lo que no estoy haciendo es centrar el texto desde el HTML a las celdas de cuadrícula respectivas.

He intentado colocar contenido en div s separados tanto dentro como fuera de los selectores left_bg y right_bg y jugar con algunas de las propiedades CSS sin éxito.

¿Cómo hago esto?

html,
body {
  margin: 0;
  padding: 0;
}

.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 100vh;
  grid-gap: 0px 0px;
}

.left_bg {
  display: subgrid;
  background-color: #3498db;
  grid-column: 1 / 1;
  grid-row: 1 / 1;
  z-index: 0;
}

.right_bg {
  display: subgrid;
  background-color: #ecf0f1;
  grid-column: 2 / 2;
  grid_row: 1 / 1;
  z-index: 0;
}

.left_text {
  grid-column: 1 / 1;
  grid-row: 1 / 1;
  position: relative;
  z-index: 1;
  justify-self: center;
  font-family: Raleway;
  font-size: large;
}

.right_text {
  grid-column: 2 / 2;
  grid_row: 1 / 1;
  position: relative;
  z-index: 1;
  justify-self: center;
  font-family: Raleway;
  font-size: large;
}
<div class="container">
  <!--everything on the page-->

  <div class="left_bg">
    <!--left background color of the page-->
  </div>
</div>

<div class="right_bg">
  <!--right background color of the page-->
</div>

<div class="left_text">
  <!--left side text content-->
  <p>Review my stuff</p>

  <div class="right_text">
    <!--right side text content-->
    <p>Hire me!</p>
  </div>
</div>
Author: Michael_B, 2017-08-06

5 answers

Esta respuesta tiene dos secciones principales:

  1. Comprender cómo funciona la alineación en la cuadrícula CSS.
  2. Seis métodos para centrar en la cuadrícula CSS.

Si solo le interesan las soluciones, omita la primera sección.


La Estructura y el Alcance del diseño de cuadrícula

Para comprender completamente cómo funciona el centrado en un contenedor de cuadrícula, es importante comprender primero la estructura y el alcance del diseño de la cuadrícula.

El HTML la estructura de un contenedor de rejilla tiene tres niveles:

  • el contenedor
  • el elemento
  • el contenido

Cada uno de estos niveles es independiente de los demás, en términos de la aplicación de las propiedades de la cuadrícula.

El ámbito de un contenedor grid está limitado a una relación padre-hijo.

Esto significa que un contenedor grid es siempre el padre y un elemento grid es siempre el hijo. Las propiedades de la cuadrícula funcionan solo dentro de esto relación.

Los descendientes de un contenedor de grid más allá de los hijos no forman parte del diseño de grid y no aceptarán las propiedades de grid. (Al menos no hasta que el subgrid se ha implementado la característica, que permitirá a los descendientes de los elementos de la cuadrícula respetar las líneas del contenedor primario.)

Aquí hay un ejemplo de los conceptos de estructura y alcance descritos anteriormente.

Imagine un tic-tac-toe-like Grid.

article {
  display: inline-grid;
  grid-template-rows: 100px 100px 100px;
  grid-template-columns: 100px 100px 100px;
  grid-gap: 3px;
}

introduzca la descripción de la imagen aquí

Quieres las X y las O centradas en cada celda.

Así que se aplica el centrado a nivel de contenedor:

article {
  display: inline-grid;
  grid-template-rows: 100px 100px 100px;
  grid-template-columns: 100px 100px 100px;
  grid-gap: 3px;
  justify-items: center;
}

Pero debido a la estructura y el alcance del diseño de cuadrícula, justify-items en el contenedor centra los elementos de la cuadrícula, no el contenido (al menos no directamente).

introduzca la descripción de la imagen aquí

article {
  display: inline-grid;
  grid-template-rows: 100px 100px 100px;
  grid-template-columns: 100px 100px 100px;
  grid-gap: 3px;
  justify-items: center;
}

section {
    border: 2px solid black;
    font-size: 3em;
}
<article>
    <section>X</section>
    <section>O</section>
    <section>X</section>
    <section>O</section>
    <section>X</section>
    <section>O</section>
    <section>X</section>
    <section>O</section>
    <section>X</section>
</article>

El mismo problema con align-items: El contenido puede estar centrado como un subproducto, pero has perdido el diseño.

article {
  display: inline-grid;
  grid-template-rows: 100px 100px 100px;
  grid-template-columns: 100px 100px 100px;
  grid-gap: 3px;
  justify-items: center;
  align-items: center;
}

introduzca la descripción de la imagen aquí

article {
  display: inline-grid;
  grid-template-rows: 100px 100px 100px;
  grid-template-columns: 100px 100px 100px;
  grid-gap: 3px;
  justify-items: center;
  align-items: center;
}

section {
    border: 2px solid black;
    font-size: 3em;
}
<article>
    <section>X</section>
    <section>O</section>
    <section>X</section>
    <section>O</section>
    <section>X</section>
    <section>O</section>
    <section>X</section>
    <section>O</section>
    <section>X</section>
</article>

Para centrar el contenido es necesario adoptar un enfoque diferente. En referencia de nuevo a la estructura y el alcance del diseño de cuadrícula, debe tratar el elemento de cuadrícula como el padre y el contenido como el hijo.

article {
  display: inline-grid;
  grid-template-rows: 100px 100px 100px;
  grid-template-columns: 100px 100px 100px;
  grid-gap: 3px;
}

section {
  display: flex;
  justify-content: center;
  align-items: center;
  border: 2px solid black;
  font-size: 3em;
}

introduzca la descripción de la imagen aquí

article {
  display: inline-grid;
  grid-template-rows: 100px 100px 100px;
  grid-template-columns: 100px 100px 100px;
  grid-gap: 3px;
}

section {
  display: flex;
  justify-content: center;
  align-items: center;
  border: 2px solid black;
  font-size: 3em;
}
<article>
  <section>X</section>
  <section>O</section>
  <section>X</section>
  <section>O</section>
  <section>X</section>
  <section>O</section>
  <section>X</section>
  <section>O</section>
  <section>X</section>
</article>

JsFiddle demo


Seis Métodos para Centrar en CSS Grid

Existen múltiples métodos para centrar los elementos de la cuadrícula y su contenido.

Aquí hay una cuadrícula básica de 2x2:

grid-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 75px;
  grid-gap: 10px;
}


/* can ignore styles below; decorative only */
grid-container {
  background-color: lightyellow;
  border: 1px solid #bbb;
  padding: 10px;
}
grid-item {
  background-color: lightgreen;
  border: 1px solid #ccc;
}
<grid-container>
  <grid-item>this text should be centered</grid-item>
  <grid-item>this text should be centered</grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
</grid-container>

Flexbox

Para una manera simple y fácil de centrar el contenido de los elementos de cuadrícula, utilice flexbox.

Más específicamente, convierta el elemento de cuadrícula en un contenedor flexible.

No hay conflicto, violación de especificaciones u otro problema con este método. Está limpio y valido.

grid-item {
  display: flex;
  align-items: center;
  justify-content: center;
}

grid-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 75px;
  grid-gap: 10px;
}

grid-item {
  display: flex;            /* new */
  align-items: center;      /* new */
  justify-content: center;  /* new */
}

/* can ignore styles below; decorative only */
grid-container {
  background-color: lightyellow;
  border: 1px solid #bbb;
  padding: 10px;
}
grid-item {
  background-color: lightgreen;
  border: 1px solid #ccc;
}
<grid-container>
  <grid-item>this text should be centered</grid-item>
  <grid-item>this text should be centered</grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
</grid-container>

Ver este post para una explicación completa:


Diseño de cuadrícula

De la misma manera que un elemento flex también puede ser un contenedor flex, un elemento grid también puede ser un contenedor grid. Esta solución es similar a la solución flexbox anterior, excepto que el centrado se realiza con grid, no flex, propiedad.

grid-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 75px;
  grid-gap: 10px;
}

grid-item {
  display: grid;            /* new */
  align-items: center;      /* new */
  justify-items: center;    /* new */
}

/* can ignore styles below; decorative only */
grid-container {
  background-color: lightyellow;
  border: 1px solid #bbb;
  padding: 10px;
}
grid-item {
  background-color: lightgreen;
  border: 1px solid #ccc;
}
<grid-container>
  <grid-item>this text should be centered</grid-item>
  <grid-item>this text should be centered</grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
</grid-container>

auto márgenes

Utilice margin: auto para centrar vertical y horizontalmente los elementos de la cuadrícula.

grid-item {
  margin: auto;
}

grid-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 75px;
  grid-gap: 10px;
}

grid-item {
  margin: auto;
}

/* can ignore styles below; decorative only */
grid-container {
  background-color: lightyellow;
  border: 1px solid #bbb;
  padding: 10px;
}
grid-item {
  background-color: lightgreen;
  border: 1px solid #ccc;
}
<grid-container>
  <grid-item>this text should be centered</grid-item>
  <grid-item>this text should be centered</grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
</grid-container>

Para centrar el contenido de los elementos de la cuadrícula, debe convertir el elemento en un contenedor de cuadrícula (o flex), envolver elementos anónimos en sus propios elementos (ya que no pueden ser dirigidos directamente por CSS) y aplicar los márgenes al nuevo elemento elemento.

grid-item {
  display: flex;
}

span, img {
  margin: auto;
}

grid-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 75px;
  grid-gap: 10px;
}

grid-item {
  display: flex;
}

span, img {
  margin: auto;
}

/* can ignore styles below; decorative only */
grid-container {
  background-color: lightyellow;
  border: 1px solid #bbb;
  padding: 10px;
}
grid-item {
  background-color: lightgreen;
  border: 1px solid #ccc;
}
<grid-container>
  <grid-item><span>this text should be centered</span></grid-item>
  <grid-item><span>this text should be centered</span></grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
</grid-container>

Propiedades de alineación de Caja

Cuando considere usar las siguientes propiedades para alinear elementos de cuadrícula, lea la sección sobre los márgenes auto arriba.

  • align-items
  • justify-items
  • align-self
  • justify-self

Https://www.w3.org/TR/css-align-3/#property-index


text-align: center

Para centrar el contenido horizontalmente en un elemento de cuadrícula, puede usar text-align propiedad.

grid-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 75px;
  grid-gap: 10px;
  text-align: center;  /* new */
}


/* can ignore styles below; decorative only */
grid-container {
  background-color: lightyellow;
  border: 1px solid #bbb;
  padding: 10px;
}
grid-item {
  background-color: lightgreen;
  border: 1px solid #ccc;
}
<grid-container>
  <grid-item>this text should be centered</grid-item>
  <grid-item>this text should be centered</grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
</grid-container>

Tenga en cuenta que para el centrado vertical, vertical-align: middle no funcionará.

Esto es porque el vertical-align la propiedad solo se aplica a los contenedores en línea y de celdas de tabla.

grid-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 75px;
  grid-gap: 10px;
  text-align: center;     /* <--- works */
  vertical-align: middle; /* <--- fails */
}


/* can ignore styles below; decorative only */
grid-container {
  background-color: lightyellow;
  border: 1px solid #bbb;
  padding: 10px;
}
grid-item {
  background-color: lightgreen;
  border: 1px solid #ccc;
}
<grid-container>
  <grid-item>this text should be centered</grid-item>
  <grid-item>this text should be centered</grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
</grid-container>

Se podría decir que display: inline-grid establece un contenedor de nivel inline, y eso sería cierto. Entonces, ¿por qué vertical-align no funciona en elementos de cuadrícula?

La razón es que en un contexto de formato de cuadrícula, los elementos se tratan como elementos a nivel de bloque.

6.1. Elemento de Cuadrícula Mostrar

El valor display de un elemento de cuadrícula es bloqueo: si el especificado display de un hijo en flujo de un elemento que genera un grid container es un valor de nivel en línea, calcula a su equivalente a nivel de bloque.

En a contexto de formato de bloque, algo que el vertical-align la propiedad fue diseñada originalmente para, el navegador no espera encontrar un elemento de nivel de bloque en un contenedor de nivel en línea. Eso es HTML no válido.


Posicionamiento CSS

Por último, hay una solución de centrado CSS general que también funciona en Grid: posicionamiento absoluto

Este es un buen método para centrar objetos que deben eliminarse del flujo del documento. Por ejemplo, si desea:

Simplemente establece position: absolute en el elemento a centrar, y position: relative en el ancestro que servirá como el bloque contenedor (normalmente es el padre). Algo como esto:

grid-item {
  position: relative;
  text-align: center;
}

span {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

grid-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 75px;
  grid-gap: 10px;
}

grid-item {
  position: relative;
  text-align: center;
}

span, img {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}


/* can ignore styles below; decorative only */

grid-container {
  background-color: lightyellow;
  border: 1px solid #bbb;
  padding: 10px;
}

grid-item {
  background-color: lightgreen;
  border: 1px solid #ccc;
}
<grid-container>
  <grid-item><span>this text should be centered</span></grid-item>
  <grid-item><span>this text should be centered</span></grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
  <grid-item><img src="http://i.imgur.com/60PVLis.png" width="50" height="50" alt=""></grid-item>
</grid-container>

Aquí hay una explicación completa de cómo funciona este método:

Aquí está la sección sobre el posicionamiento absoluto en la especificación de la cuadrícula:

 101
Author: Michael_B,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2018-05-25 16:13:10

Puede usar flexbox para centrar su texto. Por cierto, no hay necesidad de contenedores adicionales porque el texto se considera como elemento flexible anónimo.

De especificaciones de flexbox :

Cada hijo in-flow de un contenedor flex se convierte en un elemento flex, y cada corrida contigua de texto que está directamente contenida dentro de un contenedor flex se envuelve en un anónimo elemento flex. Sin embargo, un elemento flexible anónimo que contiene solo blanco espacio (es decir, caracteres que pueden ser afectados por white-space propiedad) no se representa (como si fuera display:none).

Así que simplemente haga elementos de cuadrícula como contenedores flexibles (display: flex), y agregue align-items: center y justify-content: center para centrar tanto vertical como horizontalmente.

También realizó la optimización de HTML y CSS:

html,
body {
  margin: 0;
  padding: 0;
}

.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 100vh;
  
  font-family: Raleway;
  font-size: large;
}

.left_bg,
.right_bg {
  display: flex;
  align-items: center;
  justify-content: center;
}

.left_bg {
  background-color: #3498db;
}

.right_bg {
  background-color: #ecf0f1;
}
<div class="container">
  <div class="left_bg">Review my stuff</div>
  <div class="right_bg">Hire me!</div>
</div>
 9
Author: Vadim Ovchinnikov,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2017-08-07 07:42:05

Intenta usar flex:

Plunker demo: https://plnkr.co/edit/nk02ojKuXD2tAqZiWvf9

/* Styles go here */

html,
body {
  margin: 0;
  padding: 0;
}

.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 100vh;
  grid-gap: 0px 0px;
}

.left_bg {
  background-color: #3498db;
  grid-column: 1 / 1;
  grid-row: 1 / 1;
  z-index: 0;
  display: flex;
  justify-content: center;
  align-items: center;

}

.right_bg {
  background-color: #ecf0f1;
  grid-column: 2 / 2;
  grid_row: 1 / 1;
  z-index: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.text {
  font-family: Raleway;
  font-size: large;
  text-align: center;
}

HTML

    <div class="container">
  <!--everything on the page-->

  <div class="left_bg">
    <!--left background color of the page-->
    <div class="text">
      <!--left side text content-->
      <p>Review my stuff</p>
    </div>
  </div>

  <div class="right_bg">
    <!--right background color of the page-->
    <div class="text">
      <!--right side text content-->
      <p>Hire me!</p>
    </div>
  </div>
</div>
 0
Author: Younis Ar M,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2017-08-07 07:43:49

Ni siquiera intentes usar flex; ¡quédate con css grid!! :)

Https://jsfiddle.net/ctt3bqr0/

justify-self: center;
align-self: center;

Está haciendo el trabajo de centrado aquí.

Si desea centrar algo que está dentro de div que está dentro de la celda de la cuadrícula, debe definir la cuadrícula anidada para que funcione. (Por favor, mira el violín ambos ejemplos que se muestran allí.)

Https://css-tricks.com/snippets/css/complete-guide-grid /

Salud!

 0
Author: Konrad Albrecht,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2017-10-18 21:09:36

Quieres esto?

html,
body {
  margin: 0;
  padding: 0;
}

.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 100vh;
  grid-gap: 0px 0px;
}

.left_bg {
  display: subgrid;
  background-color: #3498db;
  grid-column: 1 / 1;
  grid-row: 1 / 1;
  z-index: 0;
}

.right_bg {
  display: subgrid;
  background-color: #ecf0f1;
  grid-column: 2 / 2;
  grid_row: 1 / 1;
  z-index: 0;
}

.text {
  font-family: Raleway;
  font-size: large;
  text-align: center;
}
<div class="container">
  <!--everything on the page-->

  <div class="left_bg">
    <!--left background color of the page-->
    <div class="text">
      <!--left side text content-->
      <p>Review my stuff</p>
    </div>
  </div>

  <div class="right_bg">
    <!--right background color of the page-->
    <div class="text">
      <!--right side text content-->
      <p>Hire me!</p>
    </div>
  </div>
</div>
 -1
Author: Renato siqueira,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2017-08-07 07:32:42