CSS Layout di Holy Grail usando Flexbox


Esempio

Il layout di Holy Grail è un layout con intestazione e piè di pagina ad altezza fissa e un centro con 3 colonne. Le 3 colonne includono un sidenav a larghezza fissa, un centro fluido e una colonna per altri contenuti come gli annunci (il centro del fluido appare per primo nel markup). CSS Flexbox può essere utilizzato per ottenere questo risultato con un markup molto semplice:

Markup HTML:

<div class="container">
  <header class="header">Header</header>
  <div class="content-body">
    <main class="content">Content</main>
    <nav class="sidenav">Nav</nav>
    <aside class="ads">Ads</aside>
  </div>
  <footer class="footer">Footer</footer>
</div>

CSS:

body {
  margin: 0;
  padding: 0;
}

.container {
  display: flex;
  flex-direction: column;
  height: 100vh;
}

.header {
  flex: 0 0 50px;
}

.content-body {
  flex: 1 1 auto;
  
  display: flex;
  flex-direction: row;
}

.content-body .content {
  flex: 1 1 auto;
  overflow: auto;
}

.content-body .sidenav {
  order: -1;
  flex: 0 0 100px;
  overflow: auto;
}

.content-body .ads {
  flex: 0 0 100px;
  overflow: auto;
}

.footer {
  flex: 0 0 50px;
}

dimostrazione