Slide 1

Slide 1 text

No content

Slide 2

Slide 2 text

Hallo Freiburg!

Slide 3

Slide 3 text

Hi, I’m Chris Wright @cwrightdesign

Slide 4

Slide 4 text

Sydney, Australia

Slide 5

Slide 5 text

No content

Slide 6

Slide 6 text

No content

Slide 7

Slide 7 text

https://emails.hteumeuleu.com/trying-to-make-sense-of-gmail-css-support-e88cd7995cea

Slide 8

Slide 8 text

layout Changing the game

Slide 9

Slide 9 text

How we solve problems

Slide 10

Slide 10 text

influence the features tomorrow Features today

Slide 11

Slide 11 text

Avoiding absolutes

Slide 12

Slide 12 text

Experimentation

Slide 13

Slide 13 text

From hacks and experimentation

Slide 14

Slide 14 text

create APIs to our own CSS

Slide 15

Slide 15 text

shape the future how we can

Slide 16

Slide 16 text

Looking back

Slide 17

Slide 17 text

No content

Slide 18

Slide 18 text

No content

Slide 19

Slide 19 text

Complexity

Slide 20

Slide 20 text

The clearfix hack

Slide 21

Slide 21 text

The media query

Slide 22

Slide 22 text

No content

Slide 23

Slide 23 text

2001

Slide 24

Slide 24 text

No content

Slide 25

Slide 25 text

No content

Slide 26

Slide 26 text

Fluid image hack One defined dimension preserves aspect ratio

Slide 27

Slide 27 text

Fluid image hack One defined dimension preserves aspect ratio

Slide 28

Slide 28 text

Compressive images Images at double size with full compression https://www.filamentgroup.com/lab/compressive-images.html

Slide 29

Slide 29 text

We make creative hacks

Slide 30

Slide 30 text

Compressive images Fluid image hack Clearfix hack

Slide 31

Slide 31 text

Compressive images Fluid image hack Clearfix hack

Slide 32

Slide 32 text

Compressive images Sizes, Picture Fluid image hack Object-fit Clearfix hack Display: flowroot

Slide 33

Slide 33 text

Hacks are our desire paths

Slide 34

Slide 34 text

No content

Slide 35

Slide 35 text

hacks are a creative use of features Brilliant

Slide 36

Slide 36 text

Unique properties

Slide 37

Slide 37 text

Block padding is relative to the width of the element Intrinsic ratio padding-top: 56.25% https://alistapart.com/article/creating-intrinsic-ratios-for-video

Slide 38

Slide 38 text

Quantity queries Combining nth selector with general sibling https://alistapart.com/article/quantity-queries-for-css

Slide 39

Slide 39 text

Dirty hacks Browser isolation

Slide 40

Slide 40 text

Hacks that never leave

Slide 41

Slide 41 text

Our needs often grow beyond the tools we have

Slide 42

Slide 42 text

Layout is always hacked

Slide 43

Slide 43 text

No content

Slide 44

Slide 44 text

60+ lines of code to define column behaviour Flexbox grid example

Slide 45

Slide 45 text

35+ lines of code anytime you touch a media query Flexbox grid example

Slide 46

Slide 46 text

Now we have declarative grids

Slide 47

Slide 47 text

No content

Slide 48

Slide 48 text

No content

Slide 49

Slide 49 text

No content

Slide 50

Slide 50 text

No content

Slide 51

Slide 51 text

Fraction units, yay!

Slide 52

Slide 52 text

1 Fr 1 / 1

Slide 53

Slide 53 text

1Fr 1Fr 1 / 2 1 / 2

Slide 54

Slide 54 text

1Fr 1Fr 1Fr 1 / 3 1 / 2 1 / 3 1 / 3

Slide 55

Slide 55 text

1Fr 2Fr 1 / 3 2 / 3

Slide 56

Slide 56 text

No content

Slide 57

Slide 57 text

Repeat (2, 1Fr) 1 / 2 1 / 2

Slide 58

Slide 58 text

No content

Slide 59

Slide 59 text

Creating white space

Slide 60

Slide 60 text

No content

Slide 61

Slide 61 text

grid-column-start: 2

Slide 62

Slide 62 text

Across rows and columns

Slide 63

Slide 63 text

No content

Slide 64

Slide 64 text

grid-column: span 2;

Slide 65

Slide 65 text

60 Lines of code reduced to 1 line

Slide 66

Slide 66 text

No content

Slide 67

Slide 67 text

Building up complex grids

Slide 68

Slide 68 text

No content

Slide 69

Slide 69 text

No content

Slide 70

Slide 70 text

No content

Slide 71

Slide 71 text

No content

Slide 72

Slide 72 text

Flexible grids

Slide 73

Slide 73 text

No content

Slide 74

Slide 74 text

No content

Slide 75

Slide 75 text

No content

Slide 76

Slide 76 text

No content

Slide 77

Slide 77 text

Quantity queries meet Grid span

Slide 78

Slide 78 text

No content

Slide 79

Slide 79 text

No content

Slide 80

Slide 80 text

No content

Slide 81

Slide 81 text

Variables add simplicity

Slide 82

Slide 82 text

Variables create relationships between values

Slide 83

Slide 83 text

No content

Slide 84

Slide 84 text

No content

Slide 85

Slide 85 text

No content

Slide 86

Slide 86 text

Define how columns and spans collapse across viewports

Slide 87

Slide 87 text

Define how columns and spans collapse across viewports

Slide 88

Slide 88 text

Experimentation with values

Slide 89

Slide 89 text

Feature queries simplified

Slide 90

Slide 90 text

No content

Slide 91

Slide 91 text

No content

Slide 92

Slide 92 text

Testing Feature queries by using not

Slide 93

Slide 93 text

Components moving toward

Slide 94

Slide 94 text

From static pages to static devices

Slide 95

Slide 95 text

No content

Slide 96

Slide 96 text

http://v3.danielmall.com/articles/content-display-patterns/

Slide 97

Slide 97 text

http://bradfrost.com/blog/post/7-habits-of-highly-effective-media-queries/

Slide 98

Slide 98 text

Increased complexity, poorer maintainability

Slide 99

Slide 99 text

Average: 264 Media queries Over 50 Websites

Slide 100

Slide 100 text

Media queries are restricted to viewports and media types

Slide 101

Slide 101 text

No content

Slide 102

Slide 102 text

No content

Slide 103

Slide 103 text

No content

Slide 104

Slide 104 text

Define once, use anywhere

Slide 105

Slide 105 text

Available space is the constraint

Slide 106

Slide 106 text

http://danielmall.com/articles/content-display-patterns/

Slide 107

Slide 107 text

No content

Slide 108

Slide 108 text

evolved Media queries

Slide 109

Slide 109 text

min-width (30 em) default component

Slide 110

Slide 110 text

No content

Slide 111

Slide 111 text

Problems

Slide 112

Slide 112 text

Infinite loops

Slide 113

Slide 113 text

https://developers.google.com/web/fundamentals/performance/critical-rendering-path/analyzing-crp CSS Parsing

Slide 114

Slide 114 text

Autonomous layout

Slide 115

Slide 115 text

Flex wrap and set widths

Slide 116

Slide 116 text

Flex wrap: Two fixed widths 320px 480px = 800px +

Slide 117

Slide 117 text

Less than 800px space available

Slide 118

Slide 118 text

Flex-grow: 1

Slide 119

Slide 119 text

In practice

Slide 120

Slide 120 text

The problem: expanding evenly

Slide 121

Slide 121 text

The problem: expanding evenly

Slide 122

Slide 122 text

The flex-grow: 9999 variant http://joren.co/flex-grow-9999-hack/

Slide 123

Slide 123 text

flex: 99999 flex: 1 Only one has room to grow

Slide 124

Slide 124 text

flex: 99999 flex: 1 Only one has room to grow

Slide 125

Slide 125 text

flex: 99999 flex: 1

Slide 126

Slide 126 text

No content

Slide 127

Slide 127 text

No content

Slide 128

Slide 128 text

Multi columns

Slide 129

Slide 129 text

Multi columns column-width: 600px

Slide 130

Slide 130 text

Multi columns column-width: 600px

Slide 131

Slide 131 text

Multi columns column-width: 600px

Slide 132

Slide 132 text

Flex wrap + Column-count: auto

Slide 133

Slide 133 text

No content

Slide 134

Slide 134 text

No content

Slide 135

Slide 135 text

columns: 300px

Slide 136

Slide 136 text

columns: 300px

Slide 137

Slide 137 text

No content

Slide 138

Slide 138 text

Grid: Auto-fit and auto-fill

Slide 139

Slide 139 text

Component based imagery

Slide 140

Slide 140 text

SVG has its own document context

Slide 141

Slide 141 text

SVG can also embed HTML https://developer.mozilla.org/en/docs/Web/SVG/Element/foreignObject

Slide 142

Slide 142 text

No content

Slide 143

Slide 143 text

an API to detect size changes ResizeObserver

Slide 144

Slide 144 text

No content

Slide 145

Slide 145 text

window.onresize the old way of detecting

Slide 146

Slide 146 text

http://alistapart.com/article/container-queries-once-more-unto-the-breach

Slide 147

Slide 147 text

Element size relationships

Slide 148

Slide 148 text

No content

Slide 149

Slide 149 text

No content

Slide 150

Slide 150 text

No content

Slide 151

Slide 151 text

Can it communicate with CSS?

Slide 152

Slide 152 text

We can use CSS Variables to communicate

Slide 153

Slide 153 text

Getting variables via JS

Slide 154

Slide 154 text

Setting variables via JS

Slide 155

Slide 155 text

Fluid Typography

Slide 156

Slide 156 text

No content

Slide 157

Slide 157 text

http://jxnblk.com/fitter-happier-text/

Slide 158

Slide 158 text

https://www.smashingmagazine.com/2016/05/fluid-typography/

Slide 159

Slide 159 text

Font-size: 50ctw (not real CSS, I wish)

Slide 160

Slide 160 text

Size based on line length

Slide 161

Slide 161 text

ResizeObserver Container based fluid typography

Slide 162

Slide 162 text

No content

Slide 163

Slide 163 text

No content

Slide 164

Slide 164 text

In the browser

Slide 165

Slide 165 text

No content

Slide 166

Slide 166 text

No content

Slide 167

Slide 167 text

No content

Slide 168

Slide 168 text

No content

Slide 169

Slide 169 text

Useful for techniques that use calc()

Slide 170

Slide 170 text

An unfortunate limitation in CSS

Slide 171

Slide 171 text

No content

Slide 172

Slide 172 text

CSS can’t range match a selector

Slide 173

Slide 173 text

No content

Slide 174

Slide 174 text

Communicate shape

Slide 175

Slide 175 text

A preview might exist with different shapes http://lincolnloop.github.io/element-queries-example/

Slide 176

Slide 176 text

1:1 3:5 4:3 5:1

Slide 177

Slide 177 text

1:1 3:5 4:3 5:1 Container shapes as ratio

Slide 178

Slide 178 text

No content

Slide 179

Slide 179 text

Media queries are very good at this job

Slide 180

Slide 180 text

Let’s hack media queries!

Slide 181

Slide 181 text

@media (min-width: var(—size)) { Not valid

Slide 182

Slide 182 text

window.matchMedia(condition).matches

Slide 183

Slide 183 text

Turns out we don’t even need to use them

Slide 184

Slide 184 text

Set the conditions in variables

Slide 185

Slide 185 text

ResizeObserver detects a change, read variables

Slide 186

Slide 186 text

check if they match, add the class

Slide 187

Slide 187 text

No content

Slide 188

Slide 188 text

But browser support!

Slide 189

Slide 189 text

Looking ahead

Slide 190

Slide 190 text

Browser APIs Open for CSS

Slide 191

Slide 191 text

Houdini

Slide 192

Slide 192 text

Houdini What will mean for the web

Slide 193

Slide 193 text

Animation Paint Layout Custom @rules More powerful custom properties

Slide 194

Slide 194 text

Custom @rules

Slide 195

Slide 195 text

@container-shape(square) {}

Slide 196

Slide 196 text

@container(min-width: 400px) {}

Slide 197

Slide 197 text

Layout Designing Browser

Slide 198

Slide 198 text

Layout Black box

Slide 199

Slide 199 text

display: layout(Fluxbox)

Slide 200

Slide 200 text

No content

Slide 201

Slide 201 text

https://github.com/w3c/css-houdini-drafts/blob/master/css-layout-api/EXPLAINER.md

Slide 202

Slide 202 text

Child element positioning and placement

Slide 203

Slide 203 text

Ability for child elements to have flexbox/grid behaviour

Slide 204

Slide 204 text

Layout fragmentation (Multi columns etc)

Slide 205

Slide 205 text

how we build for browsers Redefine

Slide 206

Slide 206 text

How can we help shape the future?

Slide 207

Slide 207 text

Hacks show intent

Slide 208

Slide 208 text

No content

Slide 209

Slide 209 text

Advocacy creates impact

Slide 210

Slide 210 text

No content

Slide 211

Slide 211 text

Features will be supported one day

Slide 212

Slide 212 text

Early Feedback loop

Slide 213

Slide 213 text

WICG https://www.w3.org/community/wicg/

Slide 214

Slide 214 text

Houdini Task force https://github.com/w3c/css-houdini-drafts

Slide 215

Slide 215 text

CSS WG

Slide 216

Slide 216 text

Visibility

Slide 217

Slide 217 text

Thank you https://github.com/chriswrightdesign/changing-the-layout-game-talk

Slide 218

Slide 218 text

No content