Propiedad grid-column
La propiedad grid-column establece
la posición inicial y final de un elemento
en la cuadrícula o grid por columnas. Los valores de la propiedad pueden
ser números positivos o negativos,
especificados mediante una barra. El primer número denota
la posición inicial del elemento, el segundo - la posición final.
Si especificamos un número positivo como valor, la posición del elemento se cuenta de izquierda a derecha. Al especificar un número negativo, el elemento se ubicará en orden inverso, es decir, de derecha a izquierda.
Sintaxis
selector {
grid-column: posición inicial / posición final;
}
Ejemplo
Vamos a establecer las posiciones iniciales y finales para los elementos en la cuadrícula:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
</div>
#parent {
display: grid;
padding: 10px;
border: 2px solid #696989;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-column: 1 / 2;
}
#elem2 {
grid-column: 1 / 3;
}
#elem3 {
grid-column: 1 / 4;
}
:
Ejemplo
Y ahora vamos a especificar números negativos
en la propiedad grid-column:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
</div>
#parent {
display: grid;
padding: 10px;
border: 2px solid #696989;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-column: 1 / -2;
}
#elem2 {
grid-column: 1 / -3;
}
#elem3 {
grid-column: 1 / -4;
}
:
Ejemplo
Ahora hagamos que el primer, segundo y tercer elementos se ubiquen en la primera fila. Y que el cuarto elemento ocupe toda la segunda fila:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem4">4</div>
</div>
#parent {
display: grid;
padding: 10px;
border: 2px solid #696989;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-column: 1 / 2;
}
#elem2 {
grid-column: 2 / 3;
}
#elem3 {
grid-column: 3 / 4;
}
#elem4 {
grid-column: 1 / 4;
}
:
Ejemplo
Cuando se superponen las columnas ocupadas por elementos adyacentes, cada elemento subsiguiente se desplaza a una fila inferior. Utilicemos esta característica para hacer que el primer elemento se ubique en la primera fila, el segundo - en la segunda, y el tercero y cuarto - en la tercera fila:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem4">4</div>
</div>
#parent {
display: grid;
padding: 10px;
border: 2px solid #696989;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-column: 1 / 4;
}
#elem2 {
grid-column: 2 / 3;
}
#elem3 {
grid-column: 1 / 2;
}
#elem4 {
grid-column: 3 / 4;
}
:
Ejemplo
Combinemos las propiedades grid-column
y grid-row:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem4">4</div>
</div>
#parent {
display: grid;
grid-template-columns: 2fr 1fr 1fr;
border: 2px solid #696989;
padding: 10px;
height: 300px;
width: 400px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-row: 1 / 3;
}
#elem2 {
grid-row: 1 / 2;
}
#elem3 {
grid-row: 1 / 2;
}
#elem4 {
grid-row: 2 / 3;
grid-column: 2 / 4;
}
:
Ejemplo
Ahora hagamos que el primer y quinto bloque ocupen toda la fila, el segundo bloque - dos filas y dos columnas, y el tercer y cuarto bloques - una fila y dos columnas:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem4">4</div>
<div id="elem5">5</div>
</div>
#parent {
display: grid;
grid-template-columns: 2fr 1fr 1fr;
border: 2px solid #696989;
padding: 10px;
height: 300px;
width: 400px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-row: 1 / 2;
grid-column: 1 / 4;
}
#elem2 {
grid-row: 2 / 4;
grid-column: 1 / 2;
}
#elem3 {
grid-row: 2 / 3;
grid-column: 2 / 4;
}
#elem4 {
grid-row: 3 / 3;
grid-column: 2 / 4;
}
#elem5 {
grid-row: 4 / 5;
grid-column: 1 / 4;
}
:
Véase también
-
la propiedad
grid-row,
que establece la posición inicial y final de un elemento en la cuadrícula por filas -
la propiedad
grid-column-start,
que establece la posición inicial de un elemento en la cuadrícula por columnas -
la propiedad
grid-column-end,
que establece la posición final de un elemento en la cuadrícula por columnas -
la propiedad
grid-template-columns,
que establece la cantidad y el ancho de las columnas en la cuadrícula -
la propiedad
grid-auto-columns,
que establece la cantidad y el ancho de las columnas en la cuadrícula implícita