So erstellen Sie eine responsive Website mit CSS Grid und Flexbox

So erstellen Sie eine responsive Website mit CSS Grid und Flexbox

Dieses Beispiel implementiert ein responsives Website-Design mit CSS, HTML und JavaScript. Das Layout hat zwei Varianten, die sowohl für Desktop-Browser als auch für mobile Geräte geeignet sind.

Grundeinstellung

Beginnen Sie mit index.css und index.html aus dem Grid CSS Holy Grail Layout.

Platzieren Sie index.css und index.html im selben Ordner. Öffnen Sie index.html in einem Webbrowser.

Heiliger Gral

Layout-Design

Unser Beispiel zeigt eine Möglichkeit, die Homepage für ein fiktives Unternehmen/eine fiktive Dienstleistung zu erstellen. Die Homepage ist das erste, was der Benutzer sieht, wenn er die Website besucht.

Inhaltliche Gliederung

Die wichtigsten Informationen, die auf der Homepage erscheinen sollen, sind unten aufgeführt.

  • Name/Logo — Die Identität des Unternehmens/der Dienstleistung, befindet sich in der Kopfzeile, linksbündig.

  • Ankündigungen — Der erste Abschnitt des Hauptteils. Der Benutzer sieht diese Informationen „above the fold“, bevor er Artikel zum Verkauf sieht. Dieser Bereich kann wichtige Updates, zeitlich begrenzte Angebote oder empfohlene Artikel enthalten.

  • Artikel zum Verkauf – Der Name, die Beschreibung, der Preis und der aktuelle Bestand verschiedener Artikel zum Verkauf.

  • Bevorstehende Veranstaltungen – Informationen über zukünftige geschäftsbezogene Veranstaltungen, an denen der Benutzer möglicherweise teilnehmen möchte.

  • Botschaft des Tages – Wechselnde „Geschmacks“-Inhalte, wie ein Quiz oder ein inspirierendes Zitat.

  • Fußzeile – Urheberschafts- und/oder Copyright-Informationen.

Gliederung des Unterinhalts

Die folgenden Links und ergänzenden Informationen sind auf der Homepage zugänglich und regen den Benutzer zum Erkunden an. Dieser Teilinhalt kann je nach Anzeigegerät des Benutzers unterschiedlich im Layout erscheinen.

  • Auf einem Desktop-Browser oder einem Mobilgerät im Querformat werden alle Unterinhalte angezeigt.
  • Auf einem mobilen Gerät im Hochformat oder einem schmal verkleinerten Desktop-Browserfenster verschwinden die Seitenbereiche. Unterinhalte werden neu positioniert oder sind in einem Menü verfügbar.

Der folgende Unterinhalt ist auf der Startseite zugänglich.

  • Info – Ein Link zu einer separaten Identitätserklärungsseite. Im Desktop-/Landschaftsmodus erscheint es rechtsbündig in der Kopfzeile. Im Hochformat ist es ein Menüpunkt.

  • Kontakt — Ein Link zu einer separaten Seite mit Kontaktinformationen des Unternehmens/der Dienstleistung, wie z. B. Postanschrift, E-Mail-Adresse, Telefonnummer usw. Im Desktop-/Querformatmodus erscheint dieser Link in der Kopfzeile rechtsbündig. Im Hochformat ist es ein Menüpunkt.

  • Abschnitte — Links zu anderen Abschnitten der Website. Im Hochformat ist jeder Abschnittslink ein Menüpunkt.

  • Partner – Links zu Partnerunternehmen/-diensten. Im Desktop-/Querformatmodus werden Partner im rechten Bereich angezeigt. Im Hochformat werden sie unten im Hauptteil angezeigt.

Layout-Diagramm

Dieses Design hat zwei Layout-Varianten.

  • Ein Layout für Geräte im Querformat.
  • Ein Layout für Geräte im Hochformat.

Desktop-Browser sind mit beiden kompatibel, zeigen aber hauptsächlich das Querformat an.

Die Layouts sind wie folgt grafisch dargestellt.

Landschaftsdiagramm

Hochformat-Diagramm

HTML-Elemente

In diesem Design wird den folgenden HTML-Elementen jeweils ein bestimmter Layout-Zweck zugeordnet.

Element Zweck
Das division- oder div-Element ist ein grundlegender Baustein des Layouts. Die gesamte Seite ist in einem div enthalten, einschließlich der Komponentenrasterelemente (Kopfzeile, Bedienfelder, Hauptteil, Fußzeile). Ein div kann ein anderes div enthalten.
Enthält einen eindeutigen Abschnitt mit Informationen wie „Ankündigungen“, „Artikel zum Verkauf“ usw. In diesem Layout wird der Hauptteil als Abschnitt von Abschnitten implementiert.

Größter Überschriftentext, der für den Namen der Website verwendet wird.

Großer Überschriftentext, der für die Navigationselemente verwendet wird (Info, Kontakt).

Mittlerer Überschriftentext, der für Abschnittsüberschriften verwendet wird (Unsere Freunde, Ankündigungen).

Kleiner Überschriftentext, der für Inhaltstitel verwendet wird (Öffnungszeiten, Apfelweinfest).
Ein Textabsatz, von dem erwartet wird, dass er in die nächste Zeile fließt.
Eine Reihe von Texten im alternativen Stil, die den Absatz nicht unterbrechen.
Tabellarische Informationen, die in Zeilen und Spalten angeordnet sind, z. B. die zum Verkauf stehenden Artikel.

Flexbox

CSS Flexible Boxes (abgekürzt als Flexbox) ist ein Satz spezieller CSS-Attribute. Es erstellt Elemente, die sich je nach Inhalt und Layoutkontext automatisch ausdehnen oder zusammenziehen (“flexen”).

Ein Element mit Attributanzeige: flexbox ist ein Flexbox-Container. Wenn sich die Containerform ändert (z. B. wenn der Benutzer die Größe des Browserfensters ändert oder sein mobiles Gerät dreht), ändern seine untergeordneten Elemente ihre relative Position und/oder Form. Die Elemente biegen sich in einer Dimension, entweder horizontal (in einer Reihe) oder vertikal (in einer Spalte).

Das Layout des heiligen Grals hat fünf Hauptbereiche, die sich biegen lassen.

  • Die Kopf- und Fußzeile biegen sich horizontal (Flex-Richtung: Reihe) von links nach rechts.
  • Die linke Platte, der Hauptkörper und die rechte Platte biegen sich vertikal (Biegerichtung: Spalte) von oben nach unten.

Landschaftsflex

Im Hochformat sind die Bedienfelder ausgeblendet. Das Menü ist als Flex-Spalte implementiert.

Hochformat flex

Implementierung: CSS, JavaScript und HTML

CSS: index.css

/* element styles */
* {
  margin: 0;     /* by default, all elements (selector *) have no margin */
}
html {
  width: 100%;                    /* 100% width of parent (root) element */
  height: 100vh;                              /* 100% height of viewport */
  background: rgb(0, 0, 0, 0.1);                            /* 10% black */
  font-size: 1.0em;                                /* our root font size */
  font-family: Arial, Helvetica, sans-serif;             /* default font */
}
body {
  min-height: 100%;
}
section {
  padding: 0.5rem;
  flex-grow: 1;         /* in a flexbox, sections expand along flex axis */
}
h1 {                                           /* Website name in header */
  font-size: 2.0rem;
  font-weight: normal;
}
h2 {                                                   /* About, Contact */
  font-size: 1.25rem;
}
h3 {                                                 /* Section headings */
  font-size: 1.2rem;
  padding: 0.5rem;
}
h4 {                                               /* Section item title */
  font-weight: normal;
  padding: 0.5rem;
}
p {                                                 /* Paragraph styling */
  padding: 0.5rem;
}
a:link, a:visited {            /* anchor links, and visited anchor links */
  color: black;
  text-decoration: none;                            /* disable underline */
}
a:hover {                                 /* when anchor link is hovered */
  color: rgb(25, 25, 25);
}
a:active {                                /* when anchor link is clicked */
  color: rgb(96, 96, 96);
}
/* component styles */
#container {
  display: grid;
  height: 100%;
  grid-template-columns:
    [left] 10rem auto 10rem [right];
  grid-template-rows:
    [top] 5rem auto 5rem [bottom];
  grid-template-areas:
    "head head head"
    "panleft mainbody panright"
    "foot foot foot";
}
#header {
  grid-area: head;                  /* corresponds to grid-template-area */
  background: rgb(0, 0, 0, 0.2);                            /* 20% black */
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: baseline;  /* site name and nav item text aligns baseline */
  padding: 1.0rem;
}
#panel {                                        /* if element id="panel" */
  display: flex;                     /* this element is a flexbox parent */
  flex-direction: column;          /* its child elements flex vertically */
  padding: 0.5rem;
  background: rgb(0, 0, 0, 0.1);                            /* 10% black */
}
#panel.left {                  /* if element id="panel" and class="left" */
  grid-area: panleft;                  /* this element fills a grid area */
}
#panel.right {                /* if element id="panel" and class="right" */
  grid-area: panright;                 /* this element fills a grid area */
}
#footer {                                      /* if element id="footer" */
  grid-area: foot;                     /* this element fills a grid area */
  display: flex;                     /* this element is a flexbox parent */
  flex-direction: column;          /* its child elements flex vertically */
  justify-content: center;           /* horizontal center footer content */
  align-items: center;                 /* vertical center footer content */
  padding: 0.5rem;
  background: rgb(0, 0, 0, 0.2);
}
#mainbody {                                  /* if element id="mainbody" */
  display: flex;                     /* this element is a flexbox parent */
  flex-direction: column;          /* its child elements flex vertically */
  grid-area: mainbody;
  justify-self: center;          /* fixed-width mainbody always centered */
  width: 100%;
  min-width: 22.5rem;               /* mainbody width can't go < 22.5rem */
}
div#panel,
div#mainbody {                               /* extra space under header */
  padding-top: 0.5rem;
}
#partners, #sections {      /* if element id="partners" or id="sections" */
  display: flex;                     /* this element is a flexbox parent */
  flex-direction: row;           /* its child elements flex horizontally */
  flex-wrap: wrap;           /* its child elements can wrap to next line */
  align-content: flex-start;       /* child elements start in upper left */
}
#partners.wide {            /* if element id="partners" and class="wide" */
  display: none;              /* by default, do not display this element */
}
#menu {
  position: absolute;      /* menu position unaffected by other elements */
  right: 0;                       /* zero pixels from the right boundary */
  background: rgb(239, 239, 239);
  border: 0.15rem solid rgb(0, 0, 0, 0.4);
  visibility: hidden;        /* visibility property supports transitions */
  opacity: 0;      /* opacity + visibility transition = menu fade effect */
  z-index: 1;              /* ensure menu appears over all other content */
}
#menuitems {               /* menu is implemented as a flexbox container */
  display: flex;
  flex-direction: column;
  padding: 1rem;
}
#menuitems h3 {
  border-top: 0.15rem solid rgb(0, 0, 0, 0.1);  /* light horizontal rule */
}
#menuitems .menusec {
  border-color: rgb(0, 0, 0, 0.25);            /* darker horizontal rule */
}
#menuitems h3:hover {
  background-color: rgb(0, 0, 0, 0.1);     /* gray of rollover menuitems */
}
.menubutton {
  text-align: right;
  cursor: pointer;            /* indicates it can be clicked like a link */
  user-select: none;            /* user cannot select the button as text */
}
#menuitems .alignright {
  text-align: right;            /* right-aligned menu item text (unused) */
}
#header h1.menubutton {
  display: none;        /* in default view (landscape), hide menu button */
  border: 0.15rem solid rgb(0, 0, 0, 0);   /* (invisible) alignment shim */
}
#header .placeholder {    /* this invisible button is rendered when menu */
  color: rgb(0, 0, 0, 0); /* button is hidden, so header height matches. */
  user-select: none;       /* user can't select text of invisible button */
}
.sectionlink, .partnerlink {
  border-radius: 0.25rem;     /* give this element a slight rounded edge */
  font-weight: normal;
  font-size: 1.1rem;
  padding: 0.5rem;
  width: 7rem;                            /* fixed width for these items */
  margin-bottom: 1rem;                  /* slight margin for readability */
  background: rgb(0, 0, 0, 0.1);
}
.sectionlink:hover, .partnerlink:hover {
  background-color: rgb(0, 0, 0, 0.065);   /* brighten bg on mouse hover */
}
.partnerlink {
  height: 7rem;        /* partner elements are additionally fixed height */
}
.partnerlink.wide {
  margin: 0.5rem 1rem 0.5rem 0;      /* margins for spacing if they wrap */
}
.clickable-area {      /* use whenever a clickable area excludes margins */
  height: 100%;                 /* clickable area spans height of parent */
}
.eventitem, .announceitem, .motditem {
  margin-bottom: 0.5rem;                /* slight margin for readability */
}
.title {                                    /* e.g., "Open for business" */
  font-style: italic;
  font-weight: normal;
  font-size: 1.1rem;
}
.date {                                         /* e.g., January 1, 2021 */
  font-style: italic;
  font-size: 0.9rem;
  padding: 0 0 0 0.5rem;
  color: rgb(0, 0, 0, 0.5);
}
.navitem {                                             /* About, Contact */
  font-weight: normal;
  padding: 0 0.5rem 0 1rem;
}
.headspace, .panspace, .footspace, .bodyspace {
  flex-grow: 1;      /* these elements expand on flex axis to fill space */
}
/* table styles ("items for sale") */
table {
  border-collapse: collapse;               /* pixel-adjacent table cells */
  width: 100%;
  margin-bottom: 1rem;
}
th {
  text-align: left;
}
tr {
  margin: 4rem 0 0 0;
  border-bottom: 0.15rem solid rgb(0, 0, 0, 0.2);     /* horizontal rule */
}
td, th {
  padding: 0.5rem;
  vertical-align: top;
}
td.price {
  white-space: nowrap;        /* white space in price does not wrap line */
}
td.qty, th.qty {
  text-align: center;
}
span.perunit {
  opacity: 0.5;
}
/* responsive styles applied in portrait mode */
@media screen and (max-width: 45rem) {      /* if viewport width < 45rem */
  #panel.left {
    grid-column-end: left;         /* panel grid area shrinks to nothing */
  }
  #panel.right {
    grid-column-start: right;      /* panel grid area shrinks to nothing */
  }
  #partners.tall {
    display: none;  /* hide partners in panel (overwrites display: flex) */
  }
  #partners.wide {
    display: flex;   /* show partners in body (overwrites display: none) */
  }
  #panel,                                 /* these disappear from layout */
  #header .placeholder,
  .navitem {
    display: none;
  }
  #mainbody {
    grid-column-start: left;         /* mainbody now starts at left edge */
    grid-column-end: right;           /* mainbody now ends at right edge */
  }
  #header h1.menubutton {              /* display the header menu button */
    display: inline;                         /* overwrites display: none */
  }
}

JavaScript: index.js

Dieses JavaScript implementiert das Umschalten zum Ein-/Ausblenden des Menüs, das ausgelöst wird, wenn die Menüschaltfläche gedrückt wird.

function menuToggle(state) {
  var ele = document.getElementById('menu');
  switch(state) {
    case 'show':
      ele.style.opacity=1;
      ele.style.color="rgb(96, 96, 96)";
      ele.style.visibility='visible';
      ele.style.transition='visibility 0s, opacity 0.3s';
      break;
    case 'hide':
      ele.style.opacity=0;
      ele.style.color="black";
      ele.style.visibility='hidden';
      ele.style.transition='visibility 0.3s, opacity 0.3s'; 
      break;
  }
}

HTML: index.html

<!DOCTYPE html>
<html lang="en">
 <head>
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <meta charset="utf-8">
  <title>Title</title>
  <link rel="stylesheet" href="index.css">
  <script src="index.js"></script>
 </head>
 <body>
  <div id="menu">
   <section id="menuitems">
    <div class="menubutton">
     <h1 onclick="menuToggle('hide')" class="menubutton">☰</h1>
    </div>
    <p><!-- space above first menu item --></p>
    <a href="javascript:void(0);"><h3 class="menusec">Tips for living well</h3></a>
    <a href="javascript:void(0);"><h3>Recipes</h3></a>
    <a href="javascript:void(0);"><h3>Homesteading advice</h3></a>
    <a href="javascript:void(0);"><h3 class="menusec">About Us</h3></a>
    <a href="javascript:void(0);"><h3 class="menusec">Contact Us</h3></a>
   </section>
  </div>
  <div id="container">
   <div id="header">
    <a href="javascript:void(0);"><h1 class="logo">Our Farm Stand</h1></a>
    <div class="headspace"></div>
    <h1 onclick="menuToggle('show')" class="menubutton">☰</h1>
    <h1 class="placeholder">☰</h1>
    <h2 class="navitem">
     <a href="javascript:void(0);">
      <div class="clickable-area">About Us</div>
     </a>
    </h2>
    <h2 class="navitem">
     <a href="javascript:void(0);">
      <div class="clickable-area">Contact Us</div>
     </a>
    </h2>
   </div>
   <div id="panel" class="left">
    <section id="sections">
     <div class="sectionlink">
      <a href="javascript:void(0);">
       <div class="clickable-area">Tips for living well</div>
      </a>
     </div>
     <div class="sectionlink">
      <a href="javascript:void(0);">
       <div class="clickable-area">Recipes</div>
      </a>
     </div>
     <div class="sectionlink">
      <a href="javascript:void(0);">
      <div class="clickable-area">Homesteading advice</div>
      </a>
     </div>
    </section>
   </div>
   <div id="mainbody">
    <section class="mainbodyitems">
     <h3>Announcements</h3>
     <section class="announcements">
      <div class="announceitem">
       <h4 class="title">Open for business</h4>
       <p class="date">Jan. 15</p>
       <p>Renovations of our new storefront are complete, and we're open for business.</p>
      </div>
     </section>
     <h3>Items for sale</h3>
     <section class="forsaleitems">
     <table>
      <tr>
       <th>Item</th>
       <th>Description</th>
       <th>Price</th>
       <th class="qty">Qty</th>
      </tr>
      <tr>
       <td>Milk</td>
       <td>Good source of calcium.</td>
       <td class="price">$2 <span class="perunit">/ half gal.</span></td>
       <td class="qty">3</td>
      </tr>
      <tr>
       <td>Eggs</td>
       <td>Great for breakfast and baking.</td>
       <td class="price">$4 <span class="perunit">/ doz.</span></td>
       <td class="qty">6</td>
      </tr>
      <tr>
       <td>Whole chicken</td>
       <td>Perfect for roasting.</td>
       <td class="price">$5 <span class="perunit">/ lb.</span></td>
       <td class="qty">4</td>
      </tr>
     </table>
    </section>
    <h3>Upcoming events</h3>
    <section>
     <div class="eventitem">
     <h4 class="title">Cider Fest</h4>
     <p class="date">October 20, 2pm–6pm</p>
     <p>Celebrate the season with fresh-pressed cider from our orchards.</p>
    </div>
    <div class="eventitem">
     <h4 class="title">Bread baking workshop</h4>
     <p class="date">December 13, 9am–noon</p>
     <p>Learn how to create and cultivate a sourdough starter.</p>
     </div>
    </section>
    <h3>Message of the day</h3>
    <section>
     <div class="motditem">
      <p>Eat better food. Support your local farm stand.</p>
     </div>
    </section>
    <h3 id="partners" class="wide">Our friends</h3>
    <section id="partners" class="wide">
     <div class="partnerlink wide">
      <a href="javascript:void(0);">
       <div class="clickable-area">Green Valley Greens</div>
      </a>
     </div>
     <div class="partnerlink wide">
      <a href="javascript:void(0);">
       <div class="clickable-area">Turkey Hill Farm</div>
      </a>
     </div>
     <div class="partnerlink wide">
      <a href="javascript:void(0);">
       <div class="clickable-area">Burt's Maple Syrup</div>
      </a>
     </div>
     <div class="partnerlink wide">
      <a href="javascript:void(0);">
       <div class="clickable-area">Only Organic Seeds</div>
      </a>
     </div>
    </section>
    <div class="bodyspace"></div>
   </section>
  </div>
  <div id="panel" class="right">
   <h3>Our friends</h3>
   <section id="partners" class="tall">
    <div class="partnerlink">
     <a href="javascript:void(0);">
      <div class="clickable-area">Green Valley Greens</div>
     </a>
    </div>
    <div class="partnerlink">
     <a href="javascript:void(0);">
      <div class="clickable-area">Turkey Hill Farm</div>
     </a>
    </div>
    <div class="partnerlink">
     <a href="javascript:void(0);">
      <div class="clickable-area">Burt's Maple Syrup</div>
     </a>
    </div>
    <div class="partnerlink">
     <a href="javascript:void(0);">
      <div class="clickable-area">Only Organic Seeds</div>
     </a>
    </div>
   </section>
   </div>
   <div id="footer">
    <p>Copyright © 2022 Alice &amp; Bob's Farm Stand</p>
   </div>
  </div>
 </body>
</html>

Aussehen

Im Querformat werden die Panels angezeigt.

Querformat/Desktop-Ansicht

Landschaftsansicht

Hochformat

In der Hochformatansicht sind die Bedienfelder ausgeblendet und das Menü aktiv. Partner werden als letzter Abschnitt des Hauptteils angezeigt.

Hochformat

Neueste Artikel
Vielleicht möchten Sie lesen

LEAVE A REPLY

Please enter your comment!
Please enter your name here