i

Container Layout

Für dieses Kapitel solltest du mit einem Editor und einem Browser und nicht mit dem online Tool arbeiten.

Ziel

Im letzten Kapitel haben wir das Layout einer einfachen Karte mit Grid umgesetzt. In diesem Kapitel wollen wir Anpassungen an dem Container für die Karten vornehmen.

Aufgabe 1

Im Archiv dateien.zip findest du die Dateien 5.html mit der zugehörigen CSS Datei 5.css und dem Profilbild profilbild.jpg [1]. Die Karte ist bereits responsiv ausgestaltet. Es fehlen Konfigurationen für den Container. Bearbeite dafür die folgenden Aufgaben:

  1. Die Karte soll eine feste Höhe bekommen, denk auch an die Anpassung für breite Bildschirme in den media queries.
  2. Der Inhalt des Containers soll nicht über ihn hinausgehen, er soll scrollbar werden. Dies kann mit dem CSS Befehl overflow: scroll; errreicht werden. (Es wäre auch möglich den Inhalt abzuschneiden, dafür muss man den CSS Befehl overflow: hidden; nutzen.)
  3. Im nächsten Schritt wollen wir auch aus dem Container ein grid machen:
    • Für schmale Bildschirme haben wir nur eine Spalte mit 100% Breite und einen Abstand der Reihen von 10px.
    • Für breite Bildschirme definieren wir zwei Spalten mit jeweils 50% Breite. Hier bekommen Zeilen und Spalten einen Abstand von 10px.
    • Passe ggf. auch Attribute der Karte an, damit in beiden Varianten eine bzw. zwei Karten vollständig nebeneinander dargestellt werden.
  4. Im letzten Schritt nutzen wir den Befehl justify-items: center; für das Grid des Containers. Damit werden die Karten in ihren jeweiligen Zellen horizontal zentriert.

Du solltest jetzt einen optisch ansprechenden responsiven Container als auch darauf angepasste Karten haben.

Mögliche Lösung

mögliche Lösung schmales Layout[2]
mögliche Lösung breites Layout[3]

Erweiterung

Das responsive Layout für den Container ändert sich aktuell bei 721px Bildschirmbreite einmal. Schöner ist jedoch eine kontinuierliche Anpassung an die Bildschirmbreite. Bearbeite dafür die folgenden Aufgaben:

Aufgabe 2

  1. Der Container bekommt eine variable Breite von 80% für alle Bildschirmbreiten. Bei einer Veränderung der Bildschirmbreite wirst du dann feststellen, dass du ein deutlich flexibleres Layout erhalten hast.
  2. Es kann sein, dass das zweispaltige Layout mit den breiteren Karten schon zu früh aktiviert wird und sich die Karten überdecken. Passe daher das entsprechende media query an, damit es nicht zu einer Überdeckung kommt.
  3. Wenn du die letzte Teilaufgabe erledigt hast, wirst du feststellen, dass jetzt kurz vor dem Umbruch, im schmalen Kartenlayout, Platz für eine zweite Spalte wäre. Ergänze einen weiteren media query, der dieses Verhalten umsetzt. Achte auch hier darauf, dass sich die Karten nie überdecken.

Deine Webseite hat jetzt den folgenden Stand: Der Container hat immer eine Breite von 80% der Bildschirmbreite und es gibt drei Zustände:

  1. sehr kleine Bildschirmbreite: Karte im schmalen Format und einspaltig im Container
  2. mittlere Bildschirmbreite: Karte im schmalen Format und zweispaltig im Container
  3. große Bildschirmbreite: Karte im breiten Format und zweispaltig im Container
Mögliche Lösung

mögliche Lösung schmales Layout[4]
mögliche Lösung mittleres Layout[5]
mögliche Lösung breites Layout[6]

Wenn du magst, kannst du weitere media queries einbauen, um für noch größere Bildschirmbreiten die Anordnung der Karten im Container dreispaltig, vierspaltig,... zu machen.

Mögliche Lösung

mögliche Lösung dreispaltiges Layout[7]
mögliche Lösung vierspaltiges Layout[8]

Quellen

Suche

v
1.1.2.9.5
schuljahr.inf-schule.de/aktuell/information/informationsdarstellunginternet/html-css/exkurs-css-grid/container-layout
schuljahr.inf-schule.de/aktuell/1.1.2.9.5
schuljahr.inf-schule.de/aktuell/@/page/OHVaqCGisB7UY2tM

Rückmeldung geben