⊗mkPmLtPrm 250 of 250 menu

Praxis mit HTML- und CSS-Layouts

Üben wir die Erstellung von Layouts, indem wir sie mit Inhalt füllen. Lassen Sie uns zum Beispiel folgendes Layout erstellen:

Erstellen wir zunächst die grundlegende Struktur des Layouts:

<div class="wrapper"> <header> ... </header> <div class="container"> <aside class="left"> left </aside> <main> ... </main> <aside class="right"> right </aside> </div> <footer> site.com </footer> </div>

Kümmern wir uns nun um den Header. Wie dem Muster zu entnehmen ist, wird der Header den Seitennamen und ein Menü enthalten. Dabei sind diese Blöcke im gleichen Abstand vom linken Rand positioniert. In diesem Fall ist es logisch, sie mit einem gemeinsamen Elternelement zu kombinieren und diese Blöcke als Ganzes zu verschieben:

<div class="wrapper"> <header> <div class="block"> <div class="sitename"></div> <nav></nav> </div> </header> </div>

Fügen wir den Inhalt der Header-Blöcke hinzu:

<div class="wrapper"> <header> <div class="block"> <div class="sitename">site.com</div> <nav> <a href="#">home</a> <a href="#" class="active">blog</a> <a href="#">photos</a> <a href="#">about us</a> <a href="#">contacts</a> </nav> </div> </header> </div>

Schreiben wir nun die Stile für die Header-Blöcke. Dabei vergeben wir keine Höhe für den Header - er soll sich durch seinen Inhalt ergeben:

header { border: 1px solid black; } .block { margin: 20px 0 50px 220px; } .sitename { margin-bottom: 10px; font: 20px Arial; } nav { display: flex; width: 600px; border: 1px solid black; }

Schreiben wir den Code, der drei Spalten im Container erzeugt. Dabei vergeben wir keine Höhe für den Inhalt - sie soll sich durch seinen Inhalt ergeben:

.container { display: flex; } main { width: 660px; padding: 20px; border: 1px solid black; } .left { width: 200px; margin-right: 20px; padding: 20px; border: 1px solid black; } .right { width: 200px; margin-left: 20px; padding: 20px; border: 1px solid black; }

Schreiben wir nun die restlichen Stile unseres Layouts und erhalten die Lösung unserer Aufgabe:

<div class="wrapper"> <header> <div class="block"> <div class="sitename">site.com</div> <nav> <a href="#">home</a> <a href="#" class="active">blog</a> <a href="#">photos</a> <a href="#">about us</a> <a href="#">contacts</a> </nav> </div> </header> <div class="container"> <aside class="left"> left </aside> <main> <h1>Our blog</h1> <p> ... </p> <p> ... </p> <p> ... </p> <p> ... </p> <p> ... </p> </main> <aside class="right"> right </aside> </div> <footer> site.com </footer> </div> * { box-sizing: border-box; } .wrapper { width: 1100px; margin: 30px auto; border: 1px solid black; } header { border: 1px solid black; } .container { display: flex; } main { width: 660px; padding: 20px; border: 1px solid black; } .left { width: 200px; margin-right: 20px; padding: 20px; border: 1px solid black; } .right { width: 200px; margin-left: 20px; padding: 20px; border: 1px solid black; } footer { padding: 30px 0; border: 1px solid black; text-align: center; } .block { margin: 20px 0 50px 220px; } .sitename { margin-bottom: 10px; font: 20px Arial; } nav { display: flex; width: 600px; border: 1px solid black; } nav a { padding: 10px; color: blue; text-decoration: none; font: 15px Arial; } nav a:hover, nav a.active { color: red; text-decoration: underline; } main h1 { font: 20px "Times New Roman"; } main p { margin: 10px 0; text-align: justify; font: 15px Arial; }

Praktische Aufgaben

Laden Sie unter dem folgenden Link 1.zip ein Layout herunter. Öffnen Sie es im Browser und reproduzieren Sie die Seite nach dieser Vorlage.

Laden Sie unter dem folgenden Link 2.zip ein Layout herunter. Öffnen Sie es im Browser und reproduzieren Sie die Seite nach dieser Vorlage.

Deutsch
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Wir verwenden Cookies für den Betrieb der Website, Analyse und Personalisierung. Die Datenverarbeitung erfolgt gemäß der Datenschutzerklärung.
alle akzeptieren anpassen ablehnen