an event apart nashville: css grid layout

138
CSS Grid Layout Rachel Andrew An Event Apart Nashville, March 2016

Upload: rachel-andrew

Post on 21-Apr-2017

1.121 views

Category:

Internet


2 download

TRANSCRIPT

Page 1: An Event Apart Nashville: CSS Grid Layout

CSS Grid Layout

Rachel Andrew

An Event Apart Nashville, March 2016

Page 2: An Event Apart Nashville: CSS Grid Layout

Rachel Andrew

http://rachelandrew.co.uk

@rachelandrew

http://grabaperch.com

Page 3: An Event Apart Nashville: CSS Grid Layout

CSS in 2016 is amazing.

Page 4: An Event Apart Nashville: CSS Grid Layout

The trouble with CSS layout

• Floats and clearfix hacks

• Absolute positioning means elements are taken out of document flow and risk overlaps

• Redundant markup and positioning oddities with display: table

• White space issues with inline-block

Page 5: An Event Apart Nashville: CSS Grid Layout

https://www.flickr.com/photos/zervas/2810241612

Flexbox?

Page 6: An Event Apart Nashville: CSS Grid Layout

Seeing Flexbox as the silver bullet for layout issues is likely to lead us down

another path of layout hacks.

Page 7: An Event Apart Nashville: CSS Grid Layout

The cost of taming layout methods

• Developer hours spent learning non-obvious concepts.

• Compromises in terms of document semantics in order to achieve responsive layouts.

• Needing to lean on frameworks to help with complex math.

• Adding markup to create grids

• Using preprocessors to abstract layout hacks

Page 8: An Event Apart Nashville: CSS Grid Layout

We need a designed for purpose layout system for the sites and applications we develop today.

Page 9: An Event Apart Nashville: CSS Grid Layout

CSS Grid Layout

Page 10: An Event Apart Nashville: CSS Grid Layout

Our HTML consists of a div with a class of wrapper and two child elements, a and b.

<div class="wrapper"> <div class="a">A</div> <div class="b">B</div> </div>

Page 11: An Event Apart Nashville: CSS Grid Layout

To create a grid we use a new value of the display property.

display: grid

.wrapper { display: grid;

}

Page 12: An Event Apart Nashville: CSS Grid Layout

We describe the grid using the new properties:

grid-template-columns

grid-template-rows

.wrapper { display: grid; grid-template-columns: 100px 100px 100px; grid-template-rows: auto auto; }

Page 13: An Event Apart Nashville: CSS Grid Layout

We position items using the new properties:

grid-column-startgrid-column-endgrid-row-startgrid-row-end

.a { grid-column-start: 1; grid-column-end: 2; grid-row-start: 1; grid-row-end: 2; }

Page 14: An Event Apart Nashville: CSS Grid Layout

To position an item bottom centre, I start at column line 2 and end at column line 3.

.b { grid-column-start: 2; grid-column-end: 3; grid-row-start: 2; grid-row-end: 3; }

Page 15: An Event Apart Nashville: CSS Grid Layout

To span more tracks we just change the end row or column line.

.b { grid-column-start: 2; grid-column-end: 4; grid-row-start: 2; grid-row-end: 3; }

bit.ly/aeanv-simple

Page 16: An Event Apart Nashville: CSS Grid Layout

The longhand for line-based placement means up to 4 properties to position each element. .a {

grid-column-start: 1; grid-column-end: 2; grid-row-start: 1; grid-row-end: 2; }

.b { grid-column-start: 2; grid-column-end: 4; grid-row-start: 2; grid-row-end: 3; }

Page 17: An Event Apart Nashville: CSS Grid Layout

Declare start and end values with grid-column and grid-row.

Values are separated by a / symbol.

.a { grid-column: 1 / 2; grid-row: 1 / 2; }

.b { grid-column: 2 / 4; grid-row: 2 / 3; }

Page 18: An Event Apart Nashville: CSS Grid Layout

Declare all 4 values using the grid-area property.

Order of properties: - grid-row-start - grid-column-start - grid-row-end - grid-column-end

.a { grid-area: 1 / 1 / 2 / 2; }

.b { grid-area: 2 / 2 / 3 / 4; }

Page 19: An Event Apart Nashville: CSS Grid Layout

Grid lines relate to writing mode. In a right to left language such as

Arabic the first column line is the right-hand line.

Page 20: An Event Apart Nashville: CSS Grid Layout

Grid Terminology

Page 21: An Event Apart Nashville: CSS Grid Layout

Grid Lines

Lines can be horizontal or vertical. They are referred to by number and can be

named.

Highlighted is Column Line 2.

Page 22: An Event Apart Nashville: CSS Grid Layout

Grid Track

A Grid Track is the space between two Grid Lines. Tracks can be horizontal or

vertical (rows or columns).

The highlighted Grid Track is between Row Lines 2 and 3.

Page 23: An Event Apart Nashville: CSS Grid Layout

Grid Cell

The smallest unit on our grid, a Grid Cell is the space between four Grid Lines. It’s

just like a table cell.

The highlighted Grid Cell is between row lines 2 and 3 and column lines 2 and 3.

Page 24: An Event Apart Nashville: CSS Grid Layout

Grid Area

Any area of the Grid bound by 4 Grid Lines. It can contain many Grid Cells.

The highlighted Grid Area is between row lines 1 and 3, column lines 2 and 4.

Page 25: An Event Apart Nashville: CSS Grid Layout

Line-based placement

Page 26: An Event Apart Nashville: CSS Grid Layout
Page 27: An Event Apart Nashville: CSS Grid Layout

The HTML around my page content.

The various areas of my page are child elements of a div with a class of wrapper.

<div class="wrapper">

<header class="mainheader"></header>

<div class="panel"></div>

<div class="content"></div>

</div>

Page 28: An Event Apart Nashville: CSS Grid Layout
Page 29: An Event Apart Nashville: CSS Grid Layout

Declaring a grid on wrapper.

The grid has two columns making 3 column lines.

I have specified a column and row gap. This creates a gutter between our tracks.

.wrapper { width: 100%; max-width: 960px; margin: 0 auto; display: grid; grid-template-columns: 2fr 4fr; grid-column-gap: 2em; grid-row-gap: 20px; }

Page 30: An Event Apart Nashville: CSS Grid Layout

The fr unit

• Assigns to the track a fraction of the available space in the container.

• Before fractions are calculated the space assigned to any fixed width tracks and gaps is removed.

• Acts in a similar way to flex-grow in Flexbox.

Page 31: An Event Apart Nashville: CSS Grid Layout

Grid Layout

I am creating three grid column tracks, all 1fr in width.

This gives me three equally sized column tracks.

.wrapper { display: grid; grid-template-columns: 1fr 1fr 1fr; }

Page 32: An Event Apart Nashville: CSS Grid Layout

Grid Layout

If I create the first column as 600 pixels and then have two 1fr columns the 600 pixel track is removed from the available space and the remainder is distributed equally between the two columns.

.wrapper { display: grid; grid-template-columns: 600px 1fr 1fr; }

Page 33: An Event Apart Nashville: CSS Grid Layout

Grid Layout

With a 600 pixel column, a 1fr and a 3fr column. The 600 pixels is removed from the available space then the remaining space is divided by 4.

The 1fr column gets 25% and the 3fr column 75%.

.wrapper { display: grid; grid-template-columns: 600px 1fr 3fr; }

Page 34: An Event Apart Nashville: CSS Grid Layout

http://alistapart.com/article/holygrail

Three columns. One fixed-width sidebar for your navigation, another for, say, your Google Ads or your Flickr photos—and, as in a fancy truffle, a liquid center for the real substance.

Page 35: An Event Apart Nashville: CSS Grid Layout

Grid Layout

CSS Grid “Holy Grail”. //css

.wrapper { display: grid; grid-template-columns: 300px 1fr 300px; grid-template-rows: auto; grid-column-gap: 20px; }

.header { grid-column: 1 / 4; }

.content { grid-column: 2 / 3; grid-row: 2 / 3; }

.side1 { grid-column: 1 / 2; grid-row: 2 / 3; }

.side2 { grid-column: 3 / 4; grid-row: 2 / 3; }

.footer { grid-column: 1 / 4; grid-row: 3 / 4; }

//html <div class="wrapper"> <header class="header">This is the header</header> <article class="content"></article> <div class="side1"></div> <div class="side2"></div> <footer class="footer"></div> </div>

Page 36: An Event Apart Nashville: CSS Grid Layout
Page 37: An Event Apart Nashville: CSS Grid Layout

Declaring a grid on wrapper.

The grid has two columns and two rows, making 3 column lines and 3 row lines.

.wrapper { width: 100%; max-width: 960px; margin: 0 auto; display: grid; grid-template-columns: 2fr 4fr; grid-template-rows: auto auto; grid-column-gap: 2em; grid-row-gap: 20px; }

Page 38: An Event Apart Nashville: CSS Grid Layout
Page 39: An Event Apart Nashville: CSS Grid Layout

Positioning our elements using the grid-column and grid-row shorthand.

We can omit the -end value if only spanning 1 track.

This is all we need to do to create our layout.

.mainheader { grid-column: 1 / 3; grid-row: 1 ; }

.panel { grid-column: 1 ; grid-row: 2 ; }

.content { grid-column: 2 ; grid-row: 2 ; }

Page 40: An Event Apart Nashville: CSS Grid Layout
Page 41: An Event Apart Nashville: CSS Grid Layout

bit.ly/aeanv-line-based1

Page 42: An Event Apart Nashville: CSS Grid Layout

I can add a footer to this layout.

<div class="wrapper">

<header class="mainheader"></header>

<div class="panel"></div>

<div class="content"></div>

<footer class="mainfooter"></footer>

</div>

Page 43: An Event Apart Nashville: CSS Grid Layout

Positioning the footer after row line 3.

.mainfooter { grid-column: 1 / 3; grid-row: 3 ; }

Page 44: An Event Apart Nashville: CSS Grid Layout

bit.ly/aeanv-line-based2

Page 45: An Event Apart Nashville: CSS Grid Layout

We didn’t actually specify any row tracks.

Grid creates implicit grid lines for us.

.wrapper { display: grid; grid-template-columns: 2fr 4fr; grid-column-gap: 2em; grid-row-gap: 20px; }

.mainfooter { grid-column: 1 / 3; grid-row: 3 ; }

Page 46: An Event Apart Nashville: CSS Grid Layout

Grid lines can be explicit or implicit

• Explicit grid lines are those specified using grid-template-rows or grid-template-columns.

• Implicit lines are created when you place something into a row or column track outside of the explicit grid.

• Default behaviour is those tracks are auto sized. You can specify a size with the grid-auto-columns and grid-auto-rows properties.

Page 47: An Event Apart Nashville: CSS Grid Layout

Typically rows in our layouts are sized to fit their contents, meaning that you can avoid specifying rows and grid will create them as items are positioned into them. .wrapper {

display: grid; grid-template-columns: 2fr 4fr; grid-column-gap: 2em; grid-row-gap: 20px; }

Page 48: An Event Apart Nashville: CSS Grid Layout

Grid is “table like” however …

• Unlike a table for layout Grid does not rely on your content being a particular order in the source.

• Being entirely described in CSS we can move things around the Grid at different breakpoints, introduce or redefine a Grid for any breakpoint.

Page 49: An Event Apart Nashville: CSS Grid Layout

Using Grid to order the page elements in a single column for narrow screen widths.

.wrapper { display: grid; grid-row-gap: 10px; } .mainheader { grid-row: 1 ; }

.content { grid-row: 2 ; }

.panel { grid-row: 3 ; }

.mainfooter { grid-row: 4 ; }

Page 50: An Event Apart Nashville: CSS Grid Layout

bit.ly/aeanv-line-based3

Page 51: An Event Apart Nashville: CSS Grid Layout

Redefine the Grid at min-width 550 pixels.

Position items as in the earlier example.

@media (min-width: 550px) { .wrapper { grid-template-columns: 2fr 4fr; grid-column-gap: 2em; grid-row-gap: 20px; } .mainheader { grid-column: 1 / 3; grid-row: 1 ; } .panel { grid-column: 1 ; grid-row: 2 ; } .content { grid-column: 2 ; grid-row: 2 ; } .mainfooter { grid-column: 1 / 3; grid-row: 3 ; } }

Page 52: An Event Apart Nashville: CSS Grid Layout

Named Grid Lines

Page 53: An Event Apart Nashville: CSS Grid Layout

bit.ly/aeanv-named-lines

Page 54: An Event Apart Nashville: CSS Grid Layout

Name lines with the name in square brackets.

Remember we are naming grid lines and not grid tracks. .wrapper {

display: grid; grid-row-gap: 10px; grid-template-rows: [row-header-start] auto [row-content-start] auto [row-panel-start] auto [row-footer-start] auto [row-footer-end]; }

Page 55: An Event Apart Nashville: CSS Grid Layout

Here we are positioning based on line numbers.

.mainheader { grid-row: 1 ; }

.content { grid-row: 2 ; }

.panel { grid-row: 3 ; }

.mainfooter { grid-row: 4 ; }

Page 56: An Event Apart Nashville: CSS Grid Layout

Here we are positioning by named lines.

.mainheader { grid-row: row-header-start; }

.content { grid-row: row-content-start; }

.panel { grid-row: row-panel-start; }

.mainfooter { grid-row: row-footer-start; }

Page 57: An Event Apart Nashville: CSS Grid Layout

Named Areas

Page 58: An Event Apart Nashville: CSS Grid Layout

bit.ly/aeanv-template-areas

Page 59: An Event Apart Nashville: CSS Grid Layout

We assign a name to the elements on our page.

I am doing this outside of any Media Queries.

.mainheader { grid-area: header; }

.content { grid-area: content; }

.panel { grid-area: sidebar; }

.mainfooter { grid-area: footer; }

Page 60: An Event Apart Nashville: CSS Grid Layout

Describe the layout on the parent element using the grid-template-areas property.

.wrapper { display: grid; grid-row-gap: 10px; grid-template-areas: "header" "content" "sidebar" "footer"; }

Page 61: An Event Apart Nashville: CSS Grid Layout
Page 62: An Event Apart Nashville: CSS Grid Layout
Page 63: An Event Apart Nashville: CSS Grid Layout

Redefining the template areas for the wider layout. @media (min-width: 550px) {

.wrapper { grid-column-gap: 2em; grid-row-gap: 20px; grid-template-columns: 2fr 4fr; grid-template-areas: "header header" "sidebar content" "footer footer" }

}

Page 64: An Event Apart Nashville: CSS Grid Layout
Page 65: An Event Apart Nashville: CSS Grid Layout
Page 66: An Event Apart Nashville: CSS Grid Layout

Repeating the name of an area causes the area to span across those grid cells.

This can be seen in the header and footer of this layout.

@media (min-width: 550px) {

.wrapper { grid-column-gap: 2em; grid-row-gap: 20px; grid-template-columns: 2fr 4fr; grid-template-areas: "header header" "sidebar content" "footer footer" }

}

Page 67: An Event Apart Nashville: CSS Grid Layout

Repeating the name of an area causes the area to span across those grid cells.

This can be seen in the header and footer of this layout.

@media (min-width: 550px) {

.wrapper { grid-column-gap: 2em; grid-row-gap: 20px; grid-template-columns: 2fr 4fr; grid-template-areas: "header header" "sidebar content" " . footer" }

}

Page 68: An Event Apart Nashville: CSS Grid Layout
Page 69: An Event Apart Nashville: CSS Grid Layout

Implicit Named Grid Lines

Page 70: An Event Apart Nashville: CSS Grid Layout

Named grid areas create four implicit named lines. You can use these in the same way as lines you have explicitly named.

.wrapper { .wrapper { grid-column-gap: 2em; grid-row-gap: 20px; grid-template-columns: 2fr 4fr; grid-template-areas: "header header" "sidebar content" "footer footer" } }

.test { z-index: 100; background-color: red; grid-column: content-start; grid-row: content-start / footer-end; }

Page 71: An Event Apart Nashville: CSS Grid Layout
Page 72: An Event Apart Nashville: CSS Grid Layout

Items on the Grid can be layered using the z-index property.

Page 73: An Event Apart Nashville: CSS Grid Layout

A 12 column, flexible grid

Page 74: An Event Apart Nashville: CSS Grid Layout

The Bootstrap grid, and those in other frameworks relies on our describing the layout in the markup.

<!-- Stack the columns on mobile by making one full-width and the other half-width --> <div class="row"> <div class="col-xs-12 col-md-8">.col-xs-12 .col-md-8</div> <div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div> </div>

<!-- Columns start at 50% wide on mobile and bump up to 33.3% wide on desktop --> <div class="row"> <div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div> <div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div> <div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div> </div>

<!-- Columns are always 50% wide, on mobile and desktop --> <div class="row"> <div class="col-xs-6">.col-xs-6</div> <div class="col-xs-6">.col-xs-6</div> </div>

Page 75: An Event Apart Nashville: CSS Grid Layout

With CSS Grid Layout we describe the layout in the CSS and can redefine that description at any breakpoint.

Page 76: An Event Apart Nashville: CSS Grid Layout

getskeleton.com

Page 77: An Event Apart Nashville: CSS Grid Layout

You can use the repeat keyword to repeat all or part of the grid definition.

This would create 4 200 pixel wide tracks, separated by a 100 pixel wide track.

grid-template-columns: repeat(4, 200px 100px);

Page 78: An Event Apart Nashville: CSS Grid Layout

We can give multiple grid lines the same name.

This means we can use the span keyword to span n number of lines, rather than specifying a specific grid line.

.wrapper { grid-template-columns: repeat(4, [col-a] 200px [col-b] 100px); }

.content { grid-column: col-a 2 / span 2; }

.aside { grid-column: col-a 2 / span col-b 2; }

Page 79: An Event Apart Nashville: CSS Grid Layout

The markup used to create the Grid using the Skeleton framework.

Like the Bootstrap Grid and other similar frameworks it requires classes that describe the grid to be added to the markup.

<div class="container"> <h1>Skeleton Grid</h1> <div class="example-grid"> <div class="row"> <div class="four columns">Four columns</div> <div class="four columns">Four columns</div> <div class="four columns">Four columns</div> </div> <div class="row"> <div class="eight columns">Eight columns</div> <div class="four columns">Four columns</div> </div> <div class="row"> <div class="three columns">Three columns</div> <div class="three columns">Three columns</div> <div class="three columns">Three columns</div> <div class="three columns">Three columns</div> </div> <div class="row"> <div class="six columns">Six columns</div> <div class="six columns">Six columns</div> </div> </div>

Page 80: An Event Apart Nashville: CSS Grid Layout
Page 81: An Event Apart Nashville: CSS Grid Layout

When using CSS Grid Layout we have no need to describe our grid in markup.

<div class="wrapper skeleton"> <h1 class="header">CSS Grid Layout Version</h1> <div class="box1">Four columns</div> <div class="box2">Four columns</div> <div class="box3">Four columns</div> <div class="box4">Eight columns</div> <div class="box5">Four columns</div> <div class="box6">Three columns</div> <div class="box7">Three columns</div> <div class="box8">Three columns</div> <div class="box9">Three columns</div> <div class="box10">Six columns</div> <div class="box11">Six columns</div> </div>

Page 82: An Event Apart Nashville: CSS Grid Layout

Defining the 12 column grid.

The repeat keyword repeats the pattern of columns or rows the number of times specified before the comma.

.wrapper { display: grid; grid-template-columns: repeat(12, [col] 1fr ); grid-template-rows: repeat(5, [row] auto) ; grid-column-gap: 1em; grid-row-gap: 15px; }

Page 83: An Event Apart Nashville: CSS Grid Layout

Placing box1 on the grid.

Multiple lines have the same name. This means we can use the span keyword. Here I place box1 starting at the first line named col, spanning to the 4th line.

The box is placed in the first line named row and spans 1 line - the default.

.box1 { grid-column: col / span 4; grid-row: row ; }

Page 84: An Event Apart Nashville: CSS Grid Layout

Placing box8 on the grid.

Starting on column line 7, spanning 3 lines.

In the 3rd row named row, spanning 1 line.

.box8 { grid-column: col 7 / span 3; grid-row: row 3 ; }

Page 85: An Event Apart Nashville: CSS Grid Layout
Page 86: An Event Apart Nashville: CSS Grid Layout

With Grid Layout we can easily span rows just like columns.

.box1b { grid-column: col / span 4; grid-row: row / span 2; }

.box2b { grid-column: col 5 / span 4; grid-row: row / span 3; }

Page 87: An Event Apart Nashville: CSS Grid Layout

bit.ly/aeanv-12col

Page 88: An Event Apart Nashville: CSS Grid Layout

The header and footer span the full grid.

The content and panel display side by side.

.mainheader { grid-column: col / span 12; grid-row: row ; }

.mainfooter { grid-column: col / span 12; grid-row: row 3 ; }

.content { grid-column: col 5 / span 8; grid-row: row 2 ; }

.panel { grid-column: col / span 4; grid-row: row 2 ; }

Page 89: An Event Apart Nashville: CSS Grid Layout

bit.ly/aeanv-12col-layout

Page 90: An Event Apart Nashville: CSS Grid Layout

The header and footer span the full grid.

The content and panel display side by side.

.mainheader { grid-column: col / span 12; grid-row: row ; }

.mainfooter { grid-column: col / span 12; grid-row: row 3 ; }

.content { grid-column: col 5 / span 8; grid-row: row 2 ; }

.panel { grid-column: col / span 4; grid-row: row 2 ; }

Page 91: An Event Apart Nashville: CSS Grid Layout

I change three values to make our panel extend to the foot of the page.

.mainheader { grid-column: col / span 12; grid-row: row ; }

.mainfooter { grid-column: col 5 / span 8; grid-row: row 3 ; }

.content { grid-column: col 5 / span 8; grid-row: row 2 ; }

.panel { grid-column: col / span 4; grid-row: row 2 / span 2 ; }

Page 92: An Event Apart Nashville: CSS Grid Layout
Page 93: An Event Apart Nashville: CSS Grid Layout

Grid Item Placement Algorithm

Page 94: An Event Apart Nashville: CSS Grid Layout

http://dev.w3.org/csswg/css-grid/#grid-item-placement-algorithm

“The following grid item placement algorithm resolves automatic positions of grid items into definite positions, ensuring that every grid item has a well-defined grid area to lay out into.”

Page 95: An Event Apart Nashville: CSS Grid Layout
Page 96: An Event Apart Nashville: CSS Grid Layout

A list containing images. The landscape images are inside a list item with a class of ‘landscape’.

<ul class="wrapper"> <li><h3>1.</h3> <img src="gallery1.jpg" alt="Balloons"></li> <li class="landscape"><h3>2.</h3> <img src="gallery2.jpg" alt="Balloons"></li> <li class="landscape"><h3>3.</h3> <img src="gallery8.jpg" alt="Balloons"></li> <li><h3>4.</h3> <img src="gallery4.jpg" alt="Balloons"></li> <li><h3>7.</h3> <img src="gallery5.jpg" alt="Balloons"></li> <li class="landscape"><h3>6.</h3> <img src="gallery6.jpg" alt="Balloons"></li> <li><h3>7.</h3> <img src="gallery9.jpg" alt="Balloons"></li> </ul>

Page 97: An Event Apart Nashville: CSS Grid Layout

I have created a grid of four equal columns.

.wrapper { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; }

Page 98: An Event Apart Nashville: CSS Grid Layout
Page 99: An Event Apart Nashville: CSS Grid Layout

When using automatic placement we can create rules for items in our document - for example displaying portrait and landscape images differently.

.wrapper { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; grid-template-rows: auto; }

.landscape { grid-column-end: span 2; }

Page 100: An Event Apart Nashville: CSS Grid Layout

grid-auto-flow

The default value of grid-auto-flow is sparse. Grid will move forward placing items skipping cells if items do not fit .

Page 101: An Event Apart Nashville: CSS Grid Layout

With a dense packing mode grid will move items out of source order to backfill spaces.

.wrapper { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; grid-template-rows: auto; grid-auto-flow: dense; }

.landscape { grid-column-end: span 2; }

Page 102: An Event Apart Nashville: CSS Grid Layout

grid-auto-flow

With grid-auto-flow dense items are displayed out of source order. Grid

backfills any suitable gaps.

http://bit.ly/aeanv-autoflow-dense

Page 103: An Event Apart Nashville: CSS Grid Layout

Is Grid a competing specification to Flexbox?

Page 104: An Event Apart Nashville: CSS Grid Layout

Grid and the Box Alignment Module

Page 105: An Event Apart Nashville: CSS Grid Layout

CSS Box Alignment Module Level 3

“This module contains the features of CSS relating to the alignment of boxes within their containers in the various CSS box layout models: block layout, table layout, flex layout, and grid layout.” - https://drafts.csswg.org/css-align/

Page 106: An Event Apart Nashville: CSS Grid Layout

I can create this same layout with flexbox or Grid.

With flexbox the items are laid out in a row.

.wrapper { display: flex; }

.wrapper li { flex: 1 0 25%; }

Page 107: An Event Apart Nashville: CSS Grid Layout

I can create this same layout with flexbox or Grid.

For Grid I use a single row, 4 column Grid.

.wrapper { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; }

Page 108: An Event Apart Nashville: CSS Grid Layout

Flexbox alignment properties for the three landscape images.

http://bit.ly/aeanv-flex-align

.wrapper li:nth-child(2) { align-self: center; }

.wrapper li:nth-child(3) { align-self: flex-start; }

.wrapper li:nth-child(4) { align-self: flex-end; }

Page 109: An Event Apart Nashville: CSS Grid Layout

Grid alignment properties for the three landscape images.

http://bit.ly/aeanv-grid-align

.wrapper li:nth-child(2) { align-self: center; }

.wrapper li:nth-child(3) { align-self: start; }

.wrapper li:nth-child(4) { align-self: end; }

Page 110: An Event Apart Nashville: CSS Grid Layout

When should we use Grid instead of Flexbox then?

Page 111: An Event Apart Nashville: CSS Grid Layout

Flexbox is for 1 dimensional layout - a column OR a row.

Grid is for 2 dimensional layout - both columns AND rows.

Page 112: An Event Apart Nashville: CSS Grid Layout

Wrapping list items using flexbox.

.flex { display: flex; flex-wrap: wrap; margin: 0 -10px; }

.flex li { flex: 1 1 200px; margin: 10px; }

Page 113: An Event Apart Nashville: CSS Grid Layout
Page 114: An Event Apart Nashville: CSS Grid Layout
Page 115: An Event Apart Nashville: CSS Grid Layout

Wrapping list items with Grid Layout.

.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px 1fr)); grid-gap: 20px; }

Page 116: An Event Apart Nashville: CSS Grid Layout
Page 117: An Event Apart Nashville: CSS Grid Layout

Grid and Accessibility

Page 118: An Event Apart Nashville: CSS Grid Layout

Power and responsibility

• Good = creating the most accessible source order and using Grid or Flexbox to get the optimal display for each device.

• Bad = using Grid or Flexbox as an excuse to forget about the source.

• Terrible - stripping out semantic elements to make everything a grid or flex item.

Page 119: An Event Apart Nashville: CSS Grid Layout

https://drafts.csswg.org/css-grid/#source-independence

Grid item placement and reordering must not be used as a substitute for correct source ordering, as that can ruin the accessibility of the document.

Page 120: An Event Apart Nashville: CSS Grid Layout

http://adrianroselli.com/2015/10/html-source-order-vs-css-display-order.html

Page 121: An Event Apart Nashville: CSS Grid Layout

https://rachelandrew.co.uk/archives/2015/07/28/modern-css-layout-power-and-responsibility/

Page 122: An Event Apart Nashville: CSS Grid Layout

Nested Grids and Subgrids

Page 123: An Event Apart Nashville: CSS Grid Layout

In this markup the boxes e, f and g are children of the element with a class of d.

<div class="wrapper"> <div class="box a">A</div> <div class="box b">B</div> <div class="box c">C</div> <div class="box d"> <div class="box e">E</div> <div class="box f">F</div> <div class="box g">G</div> </div> </div>

Page 124: An Event Apart Nashville: CSS Grid Layout

I have declared a grid on the wrapper div, and positioned the immediate children - the elements with classes a to d.

.wrapper { display: grid; grid-gap: 10px; grid-template-columns: repeat(4, [col] 150px); repeat(2, [row] auto); } .a { grid-column: col / span 2; grid-row: row; } .b { grid-column: col 3 / span 2; grid-row: row; } .c { grid-column: col / span 2; grid-row: row 2; } .d{ grid-column: col 3 / span 2; grid-row: row 2; }

Page 125: An Event Apart Nashville: CSS Grid Layout
Page 126: An Event Apart Nashville: CSS Grid Layout

To make box d a grid itself I declare a grid as normal then position the children of this element.

They take their grid lines from the grid declared on box d.

.d{ grid-column: col 3 / span gutter 2; grid-row: row 2; display: grid; grid-gap: 10px; grid-template-columns: 1fr 1fr; }

.e { grid-column: 1 / 3; grid-row: 1; }

.f { grid-column: 1; grid-row: 2; }

.g { grid-column: 2; grid-row: 2; }

Page 127: An Event Apart Nashville: CSS Grid Layout
Page 128: An Event Apart Nashville: CSS Grid Layout

Declaring a subgrid

Page 129: An Event Apart Nashville: CSS Grid Layout

In our existing layout we are creating a completely new grid on box d.

.d{ grid-column: col 3 / span 2; grid-row: row 2; display: grid; grid-gap: 10px; grid-template-columns: 1fr 1fr; }

Page 130: An Event Apart Nashville: CSS Grid Layout

If we declare that this grid is a subgrid, we can then position the children of this element on the same grid their parent is placed on. .d{

grid-column: col 3 / span 2; grid-row: row 2; display: grid; grid-template-columns: subgrid; grid-template-rows: subgrid; }

Page 131: An Event Apart Nashville: CSS Grid Layout

http://dev.w3.org/csswg/css-grid/

“The following features are at-risk, and may be dropped during the CR period:

the subgrid value of grid-template-columns and grid-template-rows, and its component parts individually”

Page 132: An Event Apart Nashville: CSS Grid Layout

Without subgrid we create the potential for accessibility problems. Authors may remove semantic markup in order to use grid layout.

Page 133: An Event Apart Nashville: CSS Grid Layout

Eric Meyer, http://meyerweb.com/eric/thoughts/

“Subgrids are essential to the adoption of grids. I hope they’ll be implemented as soon as possible, and before grids are pushed into public release channels.”

Page 134: An Event Apart Nashville: CSS Grid Layout

Grid needs your feedback!

Enable Experimental Web Platform Features in Chrome.

Play with my examples and think up ways you would use Grid.

Follow the CSS Grid conversation on www-style by searching for [css-grid].

See the current issues in the Editor’s Draft http://dev.w3.org/csswg/css-grid/#issues-index

Page 135: An Event Apart Nashville: CSS Grid Layout
Page 136: An Event Apart Nashville: CSS Grid Layout

Browser SupportAll my examples work in Chrome unprefixed - you need to enable the Experimental Web Platform Features flag.

You can also use Webkit nightlies, with the -webkit prefix.

The work in Blink and Webkit is being done by Igalia, sponsored by Bloomberg.

IE10 and up has support for the old syntax, with an -ms prefix.

Grid is on the Edge backlog, marked as High Priority.

Mozilla are currently implementing Grid in Firefox. Some examples work in Firefox Nightlies.

There is a Polyfill under active development: https://github.com/FremyCompany/css-grid-polyfill/

Page 137: An Event Apart Nashville: CSS Grid Layout

More code!

I am creating a list of examples and information at:

http://gridbyexample.com

Page 138: An Event Apart Nashville: CSS Grid Layout

Thank you!

@rachelandrew