Goals
A little history
Status quo
display:grid
deep dive
Content elements with d:g
Bringing it all together
replace fluid_styled_content ASAP
provide state-of-the-art markup and styling
no need for post processing build chains
no need to rebuild standard content elements again and again (anymore)
easy and fun to use!
HTML & CSS
separation of content and presentation
remember, this:
<div class="text-center text-red-400 text-lg">
Is the exact same ignorant bloated PRESENTATIONAL garbage as:
<center><font color="#F77272" size="+1">
Apart from the latter having one extra DOM element
and the former being more code.
1kb Text < 1kb HTML < 1kb CSS < 1kb JS
Code/Content Ratio
"Performance"
semantics
How many html tags do you know?
Anatomy of a webpage:
<html>
<head></head>
<body>
</body>
</html>
selectors, i.e. :has()
custom properties aka "variables" (--*)
display:flex
display:grid
transitions
animations
HTML is already inherently responsive!
(Designers are the ones screwing that over)
BUT: different viewports / device classes
"breakpoints"
desktop tablet handheld
→ @media
queries, @container
queries
text → html → css → js
With CSS it is also easier
to just turn offflex
orgrid
to strip off columns,
than it is to add them!
But keep in mind:
different devices are also used differently!
A whole topic on its own.
Covered in depth in a different room here.
and now...
with display:grid
!
What is it all about, display:grid
?
First, the grid vocabulary
grid lines
{img}grid cell
{img}grid track
{img}grid area
{img}A basic grid
HTML
CSS
.x {
display: grid;
grid-template-columns: 1fr 1fr 1fr;
}
[result]
there are lots of css grid attribute, but we focus on
grid lines.
A grid with named lines:
CSS
.x {
display: grid;
grid-template-columns: [main-start] 1fr [content-start] 1fr [content-end] 1fr [main-end];
}
Uuh! Ugly.
A grid with named lines
CSS:
.x {
display: grid;
grid-template-columns:
[main-start] 1fr
[content-start] 1fr [content-end]
1fr [main-end];
}
Ah. Much better!
children with named columns
CSS:
.x :nth-child(1) { grid-column: main-start / main-end; }
.x :nth-child(2) { grid-column: content-start / content-end; }
.x :nth-child(3) { grid-column: content-start / main-end; }
{result}
same applies to grid-row
on top of that, there is also grid-area
... but not now.
What exactly is a content element ?
→ logically structured content
Err, what is structured content again?
Structured content refers to the concept of organizing and treating digital content like data. Publishing content as modular, discrete pieces of information that are tagged with machine-readable descriptions can transform how people find, understand, share, use, and reuse information.
from digital.gov
text
[header]
[subheader]
[bodytext]
media
[header]
[subheader]
[file(s)]
[alternative]
[title]
[description]
[copyright]
[link]
text AND media
Wait, I found some more... !
ok... , and what about responsive?
the layout of the element has to be adjusted to the viewport
"the narrower the viewport, the more linear the content flow"
But, remember, separation of concerns!
And I dont't want any of that stuff in my markup!!
So, what about the markup?
It stays the same for all elements!
(mostly)
Above, center
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link.
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon. Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon.
Above, left
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link.
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon. Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon.
Above, right
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link.
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon. Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon.
Below, center
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link.
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon. Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon.
Below, left
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link.
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon. Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon.
Below, right
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link.
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon. Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon.
In text, left
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link.
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon. Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon.
In text, right
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link.
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon. Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon.
Image besides Text, right
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link.
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon. Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon.
Image besides Text, left
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link.
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon. Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon.
Text besides Image, right
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link.
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon. Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon.
Text besides Image, left
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link.
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon. Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon.
Text + image
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon. Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon.
image + Text
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link.
Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon. Bacon ipsum dolor sit strong amet capicola jerky pork chop rump shoulder shank. Shankle strip steak pig salami link. Leberkas shoulder ham hock cow salami bacon em pork pork chop, jerky pork belly drumstick ham. Tri-tip strip steak sirloin prosciutto pastrami. Corned beef venison tenderloin, biltong meatball pork tongue short ribs jowl cow hamburger strip steak. Doner turducken jerky short loin chuck filet mignon.
and the styling ?
Easy.
;D
body {
--screen-margin : 1.5rem;
--screen-inset-width : 5fr;
--page-margin : 3.33rem;
--page-inset-left-min : 3.33rem;
--page-inset-left-max : 10rem;
--page-inset-right-min: 3.33rem;
--page-inset-right-max: 10rem;
--body-outset : 3.33rem;
--body-margin : 1.5rem;
--body-content-min : 30rem;
--body-content-max : 45rem;
margin: 0 auto;
/*max-width: 1920px;*/
}
body .grid {
display: grid;
gap: 0;
grid-template-columns:
[screen-start] var(--screen-margin)
[screen-start-inset] var(--screen-inset-width)
[page-start] var(--page-margin)
[page-start-inset] minmax( var(--page-inset-left-min), var(--page-inset-left-max) )
[body-start-outset] var(--body-outset)
[body-start] var(--body-margin)
[body-content-start]
minmax(
calc( var(--body-content-min) / 2 )
,
calc( ( var(--body-content-max) - 2 * var(--body-margin) ) / 2 )
)
[center-line]
minmax(
calc( var(--body-content-min) / 2 )
,
calc( ( var(--body-content-max) - 2 * var(--body-margin) ) / 2 )
)
[body-content-end]
var(--body-margin) [body-end]
var(--body-outset) [body-end-outset]
minmax( var(--page-inset-right-min), var(--page-inset-right-max) ) [page-end-inset]
var(--page-margin) [page-end]
var(--screen-inset-width) [screen-end-inset]
var(--screen-margin) [screen-end];
}
@media (max-width: 70rem) {
body .grid {
grid-template-columns:
[screen-start] var(--screen-margin)
[screen-start-inset] var(--screen-inset-width)
[page-start page-start-inset body-start-outset body-start] var(--body-margin)
[body-content-start] minmax( var(--body-content-min), calc( var(--body-content-max) - 2 * var(--body-margin) )) [body-content-end]
var(--body-margin) [body-end]
var(--body-outset) [body-end-outset]
minmax( var(--page-inset-right-min), var(--page-inset-right-max) ) [page-end-inset]
var(--body-outset) [page-end]
var(--screen-inset-width) [screen-end-inset]
var(--screen-margin) [screen-end];
}
}
@media (max-width: 20rem) {
body .grid {
grid-template-columns:
[screen-start] var(--screen-margin)
[screen-start-inset page-start page-start-inset body-start-outset body-start body-content-start]
minmax(0px, 1fr)
[body-content-end body-end body-end-outset page-end-inset page-end screen-end-inset]
var(--screen-margin) [screen-end];
}
}
.page-full {
grid-column: screen-start/screen-end;
}
.grid > * {
grid-column: body-content-start/body-content-end;
}
.grid .content {
grid-column : body-content-start/body-content-end;
grid-row : content-top/content-bottom;
align-content: flex-start;
}
.grid .column-body {
grid-column: body-content-start/body-content-end;
}
.grid .column-body-outset {
grid-column: body-start-outset/body-end-outset;
}
.grid .column-page {
grid-column: page-start/page-end;
}
.grid .column-page-inset {
grid-column: page-start-inset/page-end-inset;
}
.grid .column-screen {
grid-column: screen-start/screen-end;
}
.grid .column-screen-inset {
grid-column: screen-start-inset/screen-end-inset;
}
.grid .column-screen-inset.shaded {
grid-column: screen-start/screen-end;
padding: 1em;
background: #888;
margin-bottom: 1em;
overflow: hidden;
}
.grid .column-screen-inset.shaded {
}
@media (min-width: 70em) {
.column-before {
grid-column: page-start/body-start;
}
.margin-caption,
.aside,
aside:not(.footnotes):not(.sidebar),
.column-margin {
grid-column: body-end/page-end;
}
}
.grid .column-body-outset-right,
.grid .column-body-right {
grid-column: body-content-start/body-end-outset;
}
.grid .column-page-inset-right {
grid-column: body-content-start/page-end-inset;
}
.grid .column-page-right {
grid-column: body-content-start/page-end;
}
.grid .column-screen-inset-right {
grid-column: body-content-start/screen-end-inset;
}
.grid .column-screen-right {
grid-column: body-content-start/screen-end;
}
.left {
text-align: left;
padding-left: 1em;
}
.grid .column-body-outset-left,
.grid .column-body-left {
grid-column: body-start-outset/body-content-end;
}
.grid .column-page-inset-left {
grid-column: page-start-inset/body-content-end;
}
.grid .column-page-left {
grid-column: page-start/body-content-end;
}
.grid .column-screen-inset-left {
grid-column: screen-start-inset/body-content-end;
}
.grid .column-screen-left {
grid-column: screen-start/body-content-end;
}
.right {
text-align: right;
padding-right: 1em;
}
but wait, there is more!
Do we want to have custom styling (e.g. background-color)
→ [frame_class]
This is finally solved by ext:container, hopefully.
(Thank you Benny!)
[grid_class]
in the wrapper tag.
These are the Elements which are commonly used:
1 column
2 columns
3 columns
4 columns
"accordion"
tabs
slider (?)
details>summary
Accessibility, remember ;)
But I think it should.
Stay tuned!
ok, nice.
But how does this work within the backend?
Demo, or it didn't happen !
less code
better accessibility
better maintainability
easy interface for editors
release ✓
composer req markustimtner/grid_styled_content
better icons
better layout dataprocessor
documentation
cleanup
gsc styleguide
"Marketing"
Q: Can I use it with {framework} ?
A: D'oh. No. You shouldn't. Just don't.
1.0.0 2024-11-10 initial Version: presented at T3CRR24