@mittlmedien

info@mittl-medien.de

Moderne Weblayouts mit Flexbox und Grid

Über mich

 

  • Robert Mittl
  • Webentwickler
  • Joomla seit 2009
  • Begeisterung für JavaScript
  • Progressive Web App (PWA)

info@mittl-medien.de

@mittlmedien

Ohne Framework 🤔

  • schnelle Ladezeiten
  • Framework muss erlernt werden
  • flexibler und einfachere Anpassung
  • bei Verwendung einen Frameworks muss oft viel Code überschrieben werden

info@mittl-medien.de

@mittlmedien

 

Grid vs Flexbox

  • beide Techniken bieten seine Vorzüge
  • Flexbox durch Flussmethode sehr schnelle Ergebnisse
  • bei Einsatz von Grid können Layouts genauer realisiert werden
  • Flexbox kann für Grid ein Fallback sein

info@mittl-medien.de

@mittlmedien

Welche Layout Technik? 🧐

info@mittl-medien.de

@mittlmedien

Merkmale Flexbox

info@mittl-medien.de

@mittlmedien

Merkmale Grid

info@mittl-medien.de

@mittlmedien

Flexbox 👨🏻‍🏫

info@mittl-medien.de

@mittlmedien

.container {
    display: flex;
    flex-diretion: column;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    
}

.container:nth-child(1){
    flex: 1 0 min-content; /* grow | shrink | basis */
}

.container:nth-child(2){
    align-self: flex-end;
	
}

Flexbox 👨🏻‍🏫

info@mittl-medien.de

@mittlmedien

Flexbox 👨🏻‍🏫

Flexbox  Sticky Footer 👨🏻‍🏫

info@mittl-medien.de

@mittlmedien

body.classname {
  display: flex;
  min-height: 100vh;
  flex-direction: column;
}

article.website-content {
  flex: 1;
}

Flexbox  Debugging 👨🏻‍🏫

Text

Firefox Developer Tools 🚀

Flexbox  Debugging 👨🏻‍🏫

Text

Firefox Developer Tools 🚀

Grid 👨🏾‍🏫

info@mittl-medien.de

@mittlmedien

.container {
    grid-template-columns: 40px 1fr auto 50px 40px;
    grid-template-rows: 25% 100px auto;
    justify-items: space-between;
    align-items: stretch;
    grid-row-gap: 3em;
    grid-column-gap: 1vh;
    
}

.container:nth-child(1){
   grid-column-start: 1;
   grid-column-end: span col4-start;
   grid-row-start: 2;
   grid-row-end: span 2;
}

.container:nth-child(2){
    grid-column: 2 / span 3;
    grid-row: 4 / 5;
	
}

Grid Template Areas 👩🏻‍🏫

info@mittl-medien.de

@mittlmedien

.body {
    grid-template-areas: "header header header"
                       	 "nav nav ."
                         "content content aside"
                         "footer footer footer";
    grid-template-columns: 150px 1fr 1fr;
    grid-template-rows: 3fr 20px 10r 2fr;
  	
    
}

.header {
   grid-area: header;
   
}

.aside {
    grid-area: aside;
}

Internet Explorer wird nicht unterstützt.

Grid Beispiel 👩🏻‍🏫:

info@mittl-medien.de

@mittlmedien

Grid Beispiel 👩🏻‍🏫:

info@mittl-medien.de

@mittlmedien

Grid 👩🏻‍🏫:

info@mittl-medien.de

@mittlmedien

grid-template-columns: repeat( auto-fit, minmax(250px, 1fr) );

grid-template-columns: repeat( auto-fill, minmax(250px, 1fr) );

Explicit Grid

info@mittl-medien.de

@mittlmedien


.wrapper {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(5, minmax(100px, auto));
}



aside {
  grid-row: 1 / -1;
}

Text

mit -1 springt man zur letzten Zeile im Explicit Grid

Subgrid 👩🏻‍🏫:

info@mittl-medien.de

@mittlmedien

lorem ipsum lorem ipsum

Lorem

Lorem

Subgrid 👩🏻‍🏫:

info@mittl-medien.de

@mittlmedien

.grid {
    display: grid;
    grid-template-columns: [line1] 1fr [line2] 2fr [line3] 1fr [line4];
    grid-template-rows: auto auto auto;
}

.item {
    grid-column: 2 / 3;
    grid-row: 1 / 3;
    display: grid;
    grid-template-columns: subgrid;
    grid-template-rows: 10em 5em 200px 200px;
}

Grid  Sticky Footer 👨🏻‍🏫

info@mittl-medien.de

@mittlmedien

html {
  height: 100%;
}
body {
  min-height: 100%;
  display: grid;
  grid-template-rows: 1fr auto;
}
.footer {
  grid-row-start: 2;
  grid-row-end: 3;
}

Debugging

Flexbox vs Grid  Fallback

 

info@mittl-medien.de

@mittlmedien

@supports(display: flex) {
  /* definde your CSS */
}

@supports(display: grid) {
  /* define your CSS */
}

container {
	display: table;
    //display: table-cell;
}

Browser Prefix mit Webpack oder Gulp generieren

Support Flexbox

info@mittl-medien.de

@mittlmedien

Support Grid

info@mittl-medien.de

@mittlmedien

Support Subgrid

info@mittl-medien.de

@mittlmedien

Aspect Ratio

info@mittl-medien.de

@mittlmedien

Durch variable Breiten der Container ist die Höhe der Elemente oft unbekannt.

<div class="container">
  <img src="http://placeimg.com/660/943/animals" alt="dog" />
</div>
.container {
  background: gray;
  width: 90%;
  padding-bottom: calc(943px / 342 * 100);
  height: 0;
  
}

img {
  width: 100%;
}

Tipps für moderne Layouts:

info@mittl-medien.de

@mittlmedien

  • Einsatz der richtigen Tools (Flexbox, Grid, Column Layout, Floats)
  • automatisch Elemente mit Grid fließen lassen
  • feste Werte, Prozent mit minmax() arbeiten
  • Spaltenanzahl dem Layout anpassen (muss nicht 12-spaltig sein)
  • Einflussnahme auf die Zeilen (mehr Abstand)
  • Überlappung, Weißraum

Quellen und Tools:

 

  • Rachel Andrew - Codepen oder https://css-tricks.com/hello-subgrid
  • Wes Bos - Grid Course https://cssgrid.io/
  • Jen Simmons - Youtube
  • CSS Tricks und Smashing Magazin
  • 📙 Art Direction for the Web - Andy Clarke

 

Es gibt auch Grid Generatoren und Spiele!

info@mittl-medien.de

@mittlmedien

Fragen? 🤔

info@mittl-medien.de

@mittlmedien

Danke 😅

info@mittl-medien.de

@mittlmedien

Moderne Weblayouts mit Flexbox und Grid

By Robert Mittl

Moderne Weblayouts mit Flexbox und Grid

  • 1,727