Is it possible to make a grid item span from the first to the last row when I don't know the number of rows?
Lets say I have the following html with an unknown number of boxes.
How can I make the third .box
span from the first grid-line to the last?
.container { display: grid; grid-template-columns: repeat(3, minmax(10rem, 1fr)) [last-col] 35%; grid-template-rows: auto [last-line]; } .box { background-color: blue; padding: 20px; border: 1px solid red; } .box:nth-child(3) { background-color: yellow; grid-column: last-col / span 1; grid-row: 1 / last-line; }
<div class="container"> <div class="box"></div> <div class="box"></div> <div class="box">3</div> <div class="box"></div> <div class="box"></div> <div class="box"></div> <div class="box"></div> <div class="box"></div> <div class="box"></div> <div class="box"></div> <div class="box"></div> </div>
Auto-placement by column Using the property grid-auto-flow with a value of column . In this case grid will add items in rows that you have defined using grid-template-rows . When it fills up a column it will move onto the next explicit column, or create a new column track in the implicit grid.
The grid-column-end CSS property specifies a grid item's end position within the grid column by contributing a line, a span, or nothing (automatic) to its grid placement, thereby specifying the block-end edge of its grid area.
Is it possible to make a grid item span from the first to the last row when I don't know the number of rows?
A natural Grid solution to this problem appears to be missing in the current spec (Level 1). So the answer would be "no", strictly with Grid properties.
However, as pointed out in this answer, it may be possible with absolute positioning.
While CSS Grid cannot make a grid area span all columns / rows in an implicit grid, it can do the job in an explicit grid.
Use negative integers.
Here are two interesting sections in the CSS Grid specification:
7.1. The Explicit Grid
Numeric indexes in the grid-placement properties count from the edges of the explicit grid. Positive indexes count from the start side, while negative indexes count from the end side.
and here...
8.3. Line-based Placement: the
grid-row-start
,grid-column-start
,grid-row-end
, andgrid-column-end
propertiesIf a negative integer is given, it instead counts in reverse, starting from the end edge of the explicit grid.
In other words, when dealing with an explicit grid, which is a grid that you define using these properties:
grid-template-rows
grid-template-columns
grid-template-areas
... you can make a grid area span all columns by setting this rule:
grid-column: 3 / -1;
That tells the grid area to span from the third column line to the last column line.
The reverse would be:
grid-column: 1 / -3;
Again, this method works only in explicit grids.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With