« resources

Smashing Workshop

Grids & Layout

imposing structure on the page

workshops.oddbird.net/smash24/grid/

Cmd/Ctr-K for Controls

Poll… Do You Use CSS Grid?

  • ✅ regularly
  • ⚠️ sometimes
  • ❌ rarely

IM(H)O… The Best of CSS 🏆

  • Flexbox and grid are both excellent
  • I use them all the time, for different things
  • But grid may be my favorite tool in CSS
screenshot
[2010 Responsive Web Design by Ethan Marcotte ]
  • Ethan Marcotte coined the term RWD in 2010
  • He didn’t invent the idea, but he named it
  • And documented the approach,
scss…
.grid-span {
  width: percentage( /* 23.7288136% */
    ((3 * 4em) + (2 * 1em)) / ((12 * 4em) + (11 * 1em))
  );
  margin-right: percentage( /* 01.6949153% */
    1em / ((12 * 4em) + (11 * 1em))
  );
  padding-left: percentage( /* 08.4745763% */
    ((1 * 4em) + (1 * 1em)) / ((12 * 4em) + (11 * 1em))
  );
}
Watch out for sub-pixel rounding
  • Which is a lot of work to get right,
  • We have to remove all intrinsic sizing
  • And then careful math to replace all lengths with percentages
  • Everything is explicit, and fluid, and heavy on the math
  • Watch out for sub-pixel rounding!
Site wireframe drawn over a
wide 12-column 'grid'
  • After all that work
  • We get something like 12 equal columns
  • with alignment on a single axis
  • explicit breakpoints,
  • and no intrinsic sizing.

2017… CSS Grid

  • But then CSS Grid lands in 2017
  • Flexbox has already been available for several years
  • And it’s time to rethink
  • Not the goals of Responsive Design
  • But a modern approach…
Headshot of Jen Simmons, smiling

Jen Simmons… Intrinsic Web Design

  • Truly Two-Dimensional Layouts
  • Nested Contexts
  • Combine Fluid & Fixed
  • Various Stages of Squishiness
  • Content Expands & Contracts
  • Media Queries*, As Needed
Everything You Know About Web Design Just Changed
  • With truly two-dimensional layouts
  • In nested contexts
  • (we don’t have to choose between flow, flex, and grid)
  • (we can mix and match as needed)
  • Combining fluid and fixed and flexible units
  • That expand and contract at different stages
  • (rather than explicit breakpoints)
  • And the whole system can use intrinsic sizing,
  • Not always relying on explicit percentages and media queries
  • This is really a new era of web layout
  • With so much potential!
  • Jen Simmons coins a new term for this evolution
  • Intrinsic Web Design
Site wireframe drawn over a
wide 12-column 'grid'
  • Can we still make static grids,
  • With equal-width columns?
  • Yes…
css…
display: grid;
grid-template-columns: repeat(12, 1fr);
gap: 1em;
  • With a couple lines of code, and no math.
  • But…
12 equal columns, scribbled out
  • We can do so much more than that
CSS grid alignment [present, debug]
  • But first, let’s understand what a grid is
  • Note that ‘the grid’ lives between the container & the items
  • A grid can overflow the container
  • Items can overflow their grid areas
  • We get full flexibility with alignment of content/items on either axis
Grid Terminology [present, debug]
Implicit Grids [present, debug]
  • In the same way that flexbox is inline-like
  • Relying on elements to find their own size
  • Grid has a block-like default (display: grid)
  • Again, container controls the gap
  • By default we get an implicit grid
  • Each item takes one cell by default
  • New rows are auto-generated as needed
  • We get new columns if we start placing things in them
  • Everything is ‘auto’ sized, based on content

Implicit grids Generate Tracks As Needed

Explicit item placement grid-column & grid-row

Shorthand for grid-<axis>-start & grid-<axis>-end

Sizing implicit tracks… grid-auto-columns
grid-auto-rows

Overlapping content in grids [present, debug]
  • We can start using implicit grids immediately
  • For use-cases like overlapping content (demo)
  • But most often we want explicit tracks on at least one axis
  • (demo repeating gallery)

Defining Templates grid-template-columns
grid-template-rows

  • We can define a grid template on either axis,
  • Column or row tracks…

Defining Templates grid-template: <rows> / <columns>;

  • Or on both at the same time,
  • But that template is just the starting point
  • Browsers will still add implicit column & row tracks as needed

Implicit & explicit Are Not Exclusive

  • These concepts are not exclusive,
  • Implicit and explicit tracks can be combined…
Explicit Grids [present, debug]
  • So we can take the same HTML from earlier
  • And let’s add some explicit track sizes
  • With grid, can coordinate it all from the container
  • (Even when using intrinsic sizes)
  • That helps us change the layout in one place

Fluid & Fixed 20em 25% 200px

Fluid Until Fixed minmax(min-content, 1fr)

Fitted… fit-content(<limit>)

Similar to clamp(auto, max-content, <limit>)

Repeating… repeat(<count>, <tracks>)

Don’t get Lost in Syntax

  • Those are the basic concepts
  • But there’s so much we can do
  • People sometimes get lost in the all the options
  • Don’t let that happen!

Essential Use Cases

  1. Auto-fit for cards & galleries
  2. Named areas for layout
  3. Named lines for prose
  4. Overlapping layouts
  • We’ll focus on several essential use-cases
  • Which demonstrate different ways of using grids
  • If you feel overwhelmed with all the syntax,
  • I’d recommend picking one one these that you need,
  • And just working that into your projects

auto_-fit_ or -fill, Replacing Media Queries

  • We already saw a basic repeating grid
  • By making it repeat a specific number of times
  • But CSS can do some of that work for us,
  • So that we don’t need media queries as often
Auto-fit & auto-fill [present, debug]

demo:

  • replace media with auto fit & fill
  • fixed width vs minmax(<min>, 1fr)
  • more flexible small-screen <min> to avoid overflow
  • jump from 1 to 3 columns
Auto-Fit Grid [present, debug]
  • Stacy has a great demo taking this even farther
  • To create a masonry-like image gallery
  1. Auto-fit for cards & galleries
  2. Named areas for layout

  3. Named lines for prose
  4. Overlapping layouts
  • We also created a basic four-part layout
  • When we were talking about explicit grids
  • But we can improve on that with named grid areas!
Explicit Grids [present, debug]

demo:

  • name the areas
  • assign items to areas
  • change columns at breakpoint
Variations on a media-object [present, debug]
  • We can also adjust the template on the fly
  • Using selectors or variables
  1. Auto-fit for cards & galleries
  2. Named areas for layout
  3. Named lines for prose

  4. Overlapping layouts
  • It’s not just areas,
  • We can also name individual grid lines
Named grid lines [present, debug]

Names Areas

with matching *-start & *-end names

  1. Auto-fit for cards & galleries
  2. Named areas for layout
  3. Named lines for prose
  4. Overlapping layouts

  • We can use the interaction between named lines and named areas
  • To create more interesting and overlapped layouts
Overlapping Named Lines [present, debug]

Subgrid

as column or row template

Support data from CanIUse.com on the css-subgrid feature
Baseline 2023 Newly available [Can I Use]
Subgrid Forms [present, debug]
Stages of Squishiness [present, debug]
Understanding 1fr [present, debug]

🤔 Nested Contexts ??

Content Expands & Contracts ??

Media vs Container [live code, present, debug]
Statue of The Thinker
with a scribbled thought bubble asking:
do containers know stuff? photo: Avery Evans

Container queries will never be possible on the web. They would cause infinite layout loops.

— Browsers, a paraphrase (circa 2020)

The pink box is now labeled
extrinsic size (imposed from outside),
and the oveflowing blue text
now has a dashed box and says
intrinsic size (from the content)
The intrinsic/extrinsic diagram
with red circles and arrows and question-marks
scribbled all over it
Support data from CanIUse.com on the css-container-queries feature
[Can I Use]
Media vs Container (Live Demo) [present, debug]
The thinker
with a red scribbled thought bubble:
how?!

*Some Restrictions Apply

We can’t affect The Container That We Query

Directly or indirectly

We Need to Turn Off Intrinsic Sizing

The intrinsic/extrinsic diagram
with the intrinsic content sizing
scribbled out

CSS Containment

contain: size | layout | style | paint;

Avoid internal impacts on external elements…
CSS is Rad [present, debug]

Block boxes get their inline-size from Context (extrinsic).

— Me, Monday

Block boxes get their block-size from Content (intrinsic).

— Me, Monday

👍🏼 Inline-Only Containment

Ancestor Layout Loops with Single-Axis Containment

👎🏼 Block-Only Containment

We can only Measure The Axis We Contain

Also need to Contain Layout* & Style

*This is being relaxed!
Understanding containment [present, debug]
  • Containers should no longer apply layout containment!
  • Still create ‘formatting context’
  • Still contain counters

Contain inline-size For Most Containers

Contain size For Scroll Containers

Containing Size [present, debug]

Since… Containment is Invasive

We create Explicit Containers

css…
container-type: inline-size;
contain: inline-size layout style;

Recommended… Name Your Containers

css…
main {
  container: layout main / inline-size;
}
container-name [/ container-type]?
css…
@container layout (min-width: 40em) {
  .conditional { /* … */ }
}

@container main (min-width: 40em) {
  .conditional { /* … */ }
}

Finding Containers

  1. For each matched element
  2. Find the nearest ancestor that has…
    • Any required container name
    • Any required container types

Containers Can’t Self-Query

(That would introduce loops!)

Always Measuring an Ancestor

(can’t change what you measure!)

Enter the 36 Chambers [present, debug]

Always Measuring an Element

Bonus! Container Queries Measure Actual Styles

Computed values on the container element
Size queries, relative/var units [present, debug]

Grid Tracks & Flex Sizing?

No element to measure…

Three mud turtles
on a small log
surrounded by water.
Flexbox cards, with Container Queries [present, debug]
Container Query Bookstore [present, debug]
Container Query Blinds v2 [present, debug]

For legacy reasons… No Default Containers

(we shouldn’t rely on body style propagation)
css…
body > :is(header, main, footer, aside) {
  container: layout / inline-size;
}
Simplest Solution…

also… Container Query Units

cqw | cqh | cqi | cqb | cqmin | cqmax

Default unit container The Small Viewport

On an example phone,
the large viewport fills the full screen
with all browser chrome hidden -
the small viewport fills the remaining space
when top and bottom browser chrome are visible
The Large, Small, and Dynamic Viewports by Bramus Van Damme
cat in a box, thinking
'OMG I have so many questions for this damn box'
Photo by Sahand Babali on Unsplash
css…
@container style(--colors: invert) {}
Style Queries

Always Queries Direct Parent

Unless you query a specific container-name

No containment required
Style query button themes [present, debug]
Support data from CanIUse.com on the css-container-queries-style feature
[Can I Use]

Style Queries… Only Custom Properties*

* for now **
** but maybe forever?

State Queries (???)

CSSWG issue for state queries
css…
@container state(stuck) {}
@container state(snapped) {}
@container state(overflowing) {}
???
Chrome Explainer [present, debug]
« resources
Bring this workshop to your company.
Slide Controls

View:

Navigate slides using the arrow-keys.