Die Abschnitte im Inhaltsbereich

Mit Pseudo-Element 'nth-child(n)'

Auf der Startseite (index.html) sehen Sie im Inhaltsbereich mehrere Abschnitte, die farbig getrennt sind. Wie wir diese angelegt haben und wie Sie auch mehr oder weniger Abschnitte anlegen können, erklären wir Ihnen nachstehend.

Der Pseudo-Selektor :nth-child(n) ist sehr hilfreich, wenn man gleiche Elemente innerhalb eines Elternelement verschieden aussehen lassen möchte. Insbesondere bei Wiederholungen ist dies effektiv.

Alle Möglichkeiten:

SELFHTML-Wiki beschreibt es, aber noch viel übersichtlicher und mit sehr vielen Beispielen erklärt es die Webseite h5c3 .

Die wichtigsten Möglichkeiten:

Wie an den vorstehend genannten Links zu sehen, gibt es mehrere 'nth-child-Selektoren'. Nachfolgend möchten wir aber Ihen die wichtigsten beschreiben:

1.) Einfache 'nth-child-Selektoren':

1.a)
'nth-child(1)' spricht den ersten Abschnitt an.
'nth-child(2)' spricht den zweiten Abschnitt an.
'nth-child(3)' spricht den dritten Abschnitt an.
'nth-child(4)' spricht den vierten Abschnitt an usw.

1b)
'nth-child(odd)' spricht jeden ungeraden Abschnitt an (also 1, 3 ,5, 7 usw).
'nth-child(even)' spricht jeden geraden Abschnitt an (also 2, 4, 6, 8 usw).


2.) Erweiterte 'nth-child-Selektoren':
Jetzt wird es noch variabler und effektiver. Hier im Beispiel die Anweisungen für jeden dritten anzusprechenden Abschnitt.

'nth-child(3n+1)' spricht den ersten Abschnitt an und ab diesen jeden dritten Abschnitt.
D.h. Abschnitt 1, Abschnitt 4, Abschnitt 7 usw. sind identisch.

'nth-child(3n+2)' ist für den zweiten Abschnitt zuständig und ab diesen wird jeder dritte Abschnitt angesprochen.
D.h. Abschnitt 2, Abschnitt 5, Abschnitt 8 usw. sind identisch.

'nth-child(3n+3)' spricht den dritten Abschnitt an und ab diesen jeden dritten Abschnitt.
D.h. Abschnitt 3, Abschnitt 6, Abschnitt 9 usw. sind identisch.

'nth-child(3n+4)' spricht den vierten Abschnitt an und ab diesen jeden dritten Abschnitt.
D.h. Abschnitt 4, Abschnitt 7, Abschnitt 10 usw. sind identisch.

Wie funktioniert es in diesem Template ?

So haben wir den 'nth-child-Selektor' für die Abschnitte in der Datei format.css getätigt. Und zwar haben wir den nth-child-Selektor auf unsere CSS-Klasse namens 'section-content' gelegt und 'Erweiterte nth-child-Selektoren' eingesetzt.

CSS
<!-- Allgemeines Beispiel-->
.section-content:nth-child(3n+1) {
background:white;
color:#000;
}
.section-content:nth-child(3n+2) {
background:black;
color:#fff;
}
.section-content:nth-child(3n+3) {
background:#dfdfdf;
color:#2f2f2f;
}


So sieht ein Abschnitt in der HTML-Datei aus:
HTML
<!-- ABSCHNITT -->
<div class="section-content">
<div class="content">
... Inhalt ...
</div>
</div>
<!-- E N D E ABSCHNITT -->
So sehen zwei Abschnitte in der HTML-Datei aus:
HTML
<!-- ABSCHNITT -->
<div class="section-content">
<div class="content">
... Inhalt Abschnitt 1 ...
</div>
</div>
<!-- E N D E ABSCHNITT -->

<!-- ABSCHNITT -->
<div class="section-content">
<div class="content">
... Inhalt Abschnitt 2 ...
</div>
</div>
<!-- E N D E ABSCHNITT -->

Sehr praktisch und übersichtlich: Der Code für die Abschnitte ist also in der HTML-Datei immer der gleiche, egal wieviele Abschnitte. Auf den Unterseiten haben wir nur einen einzigen Abschnitt . Da wir mit den selben Farben arbeiten, wie im bereits definierten Abschnitt 1, müssen wir nichts weiter tun.

* * * * *

Nur für den Fall, das wir auf den Unterseiten abweichenden Farben vom Abschnitt 1 der Startseite haben wollen, könnten wir dieses mit einem zugefügtem id-Selektor bewerkstelligen, wie folgt.
CSS
<!-- Allgemeines Beispiel-->
.section-content:nth-child(1)#unterseite  {
background:dodgerblue;
color:#fff;
}

HTML
<!-- ABSCHNITT -->
<div class="section-content" id="unterseite">
<div class="content">
... Inhalt ...
</div>
</div>
<!-- E N D E ABSCHNITT -->

 

Die Spalten / Bilder

Worum geht es

Thema ist die Anordnung der Boxen bzw. wie regelt man mehrspaltige Boxen. Sobald man alles nur einspaltig untereinander anordnet, braucht man sich keine Gedanken zu machen, wobei so eine einspaltige Anordung im heutigen Webdesign natürlich kaum vorkommt. Wenn man aber mehr als eine Box/Spalte verwendet, welche nicht mehr nur untereinander sondern in Boxen/Spalten auch nebeneinander stehen sollen, ist für die Verwaltung der Boxen/Spalten irgendein individuell frei auszuwählendes Bildsystems (genannt: GRID, ein sog. Gestaltungsraster) zu bestimmen, um eine Anordnung in Spalten und Reihen zu verwalten. Dieses Gestaltungsraster bestimmen alleine Sie durch Ihre Codierung von HTML und CSS.

GRID-System

Grid heißt soviel wie Gitter oder Netz. Ein GRID-System ist im Prinzip die Basis für die Anordnung von Texten, Bildern oder anderen Objekten innerhalb einer Webseite. Ganz grob geht es darum, eine unterschiedliche Anzahl von Boxen in so einem Spalten-Netz zu arrangieren und zu bestimmen, mit welcher Technik sich diese Boxen verhalten sollen.
Hinweis dazu: Es gibt unterschiedliche Techniken, die alle ihre Vor-und Nachteile haben, wie zum Beispiel float, display:inline-block, display:table, display:flex oder display:grid.

Responsive GRID-System

Nun geht es darum eine Webseite responsive zu gestalten. In einem zweiten Schritt wird deshalb aus einem GRID-System ein Responsive GRID-System, d.h. mit Hilfe der CSS-Media-Queries, also den Bildschirmabfragen, erfolgt eine Anpassung der Boxen in Breite und Anzahl an die verschiedenen Bildschirmgrößen von Smartphone bis Desktop-PC.

Unser 'RESPONSIVE GRID' funktioniert so

Es sind übrigens zwei Systeme mit unterschiedlicher Technik. Je nach Template verwenden wir eines davon oder auch beide.

- Gridsytem #1 arbeitet mit der Technik 'display:inline-block'.
- Gridsytem #2 arbeitet mit der Technik 'display:table'.

Klar kommt man auch mit einem einzigen Grid-System aus, das zweite (mit der Technik'display:table') ist für besondere Situationen, denn es ermöglicht, das die Boxen auch bei unterschiedlich langem Inhalt der Boxen alle auf einer Höhe abschließen. Ein weiterer Vorteil ist die unkomplizierte vertikale Zentrierung mit CSS-vertical-align (top, middle, bottom). Nachfolgend eine Hilfestellung zu den wesentlichen Einstellungen:

Allgemeine Einstellungen


Bevor wir zu den 2 GRID-Systemen kommen, erst einmal wichtige allgemeine CSS-Einstellungen. Diese gelten für beide GRID-Systeme bzw. sind auch gültig, wenn Sie keine der GRID-Systeme verwenden. Max-with auf dem 'img' ist dafür da, wenn sie eigene Bilder unabhängig von diesem Bildsystem einsetzen. Diese Bilder sind dann maximal so gross wie die Original-Abmessungen des Bildes bzw. des umgebenen Containers und skalieren responsive.
CSS
img {max-width: 100%;
height: auto;
margin:0 auto;
}


Hier ist das Border-Box-Modell eingeschaltet, d.h. padding und border werden in die Box hinein gerechnet und nicht oben drauf addiert.
CSS
*, *:before, *:after {
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
box-sizing: border-box;
}


GRIDSYSTEM #1


Die Technik mit 'display:inline-block':

Nachfolgend ein Beispiel, so oder ähnlich könnte es aussehen:

1. Die 'img' im Bildsystem bekommen 100% responsive Breiten-Anpassung.
CSS
.wrapper-box img {width: 100%;
display:inline-block;
height: auto;
margin:0 auto;
}


2. Jetzt werden die Boxen für das Bildsystem angelegt. Alle Boxen bekommen an linker und rechter Seite einen 'minus-margin' um den bekannten INLINE-BLOCK-WHITESPACE-BUG auszugleichen. Da unsere Seite ja 'mobile-first' angelegt ist, starten alle Boxen mit einer Breite von 100%, d.h. alle Boxen stehen zunächst untereinander.Um die Boxen in Spalten mit Prozent von 100%, 50%, 33.33% und 25% anzuordnen, genügen uns die folgenden CSS-Klassen:

.box-1_of_1
.box-1_of_2
.box-1_of_3
.box-1_of_4

Um für die Boxen namens '.box-1_of_2', .box-1_of_3' und '.box-1_of_4' eine Alternative für einen davon abweichenden Breakpoint zu haben, könnte man als Beispiel zusätzlich noch die folgenden CSS-Klassen angelegen:

.box-1_of_2b
.box-1_of_3b
.box-1_of_4b
CSS
.wrapper-box {
text-align:center;
padding:1rem;margin: 0;
}

.box-1_of_1 ,
.box-1_of_2 ,
.box-1_of_2b ,
.box-1_of_3 ,
.box-1_of_4,
.box-1_of_4b
{width:100%;
display:inline-block;
vertical-align:top;
padding:1rem;
margin:0 -.25rem 0 -.25rem;
}

3. Mit den Bildschirmabfragen (Media Queries) setzen wir nun die Breakpoints. Wie immer sind diese Breakpoints nicht festgesetzt und können verändert und erweitert werden.
CSS
@media (min-width: 480px) {
.box-1_of_4 {width: 50%;}
}

@media (min-width: 768px) {
.box-1_of_1 {width: 50%;}
.box-1_of_2 {width: 50%;}
.box-1_of_2b {width: 100%;}
.box-1_of_3 {width: 33.33%;}
.box-1_of_4 {width: 25%;}
.box-1_of_4b {width: 50%;}
}

@media (min-width: 800px) {
.box-1_of_2b {width: 50%;}
}


GRIDSYSTEM #2


1. Die Technik mit 'display:table': So sieht es bei zwei Boxen aus, 'table-cell' stellt die Boxen nebeneinander und 'mit 'table-row' werden die Boxen untereinander platziert, mit 'height' kann eine Mindesthöhe angegeben werden.

CSS
.wrapper-box-table {
display:table;
width:100%;
text-align:center;
}

.box-tabcell-2 {
display:table-cell;
width: 100%;
height:20rem;
vertical-align:middle;
padding:1rem;
}

/* tabellenzelle-reihe */
.tabrow {display:table-row;
}


HTML
<div class="wrapper-box-table">

<span class="box-tabcell-2">
...Inhalt...
</span>

<span class="tabrow"></span>

<span class="box-tabcell-2">
...Inhalt...
</span>

</div>


2. Mit den Bildschirmabfragen (Media Queries) setzen wir nun die Breakpoints. Die Box bekommt jetzt 50% Breite und die Zellenreihe (table-row) wird mit 'display:none' ausgeschaltet, so das jetzt beide Boxen nebeneinander stehen.

CSS
@media (min-width: 1024px) {

.box-tabcell-2 {width: 50%; }

.tabrow {display:none }
}

 

Die Schrift

Webfonts

In diesem Template werden Google Webfonts verwendet. Diese sind ja kostenlos und beliebt. Es ist die Schriften 'OPEN SANS', welche direkt im Template integriert ist und somit auch ohne Internet-Verbindung angezeigt wird. Die Schrift haben wir über das HTML Link-Element eingebunden.
HTML
<link rel="stylesheet" href="css/font-open-sans-light.css" type="text/css">

Wenn Sie diese Schriften nicht verwenden wollen bzw. sich für andere Schriften entscheiden, so nehmen Sie einfach den Link-Verweis aus der HTML-Seite heraus, damit die Schriften nicht geladen werden.

 

Bilder

Hinweis: Die Fotos in dieser Vorlage sind von https://picjumbo.com/ . Wir haben diese responsive angelegt. Gerne können Sie natürlich auch Ihre eigenen Fotos verwenden.

 

Icons

Wir verwenden Icon-Fonts

Font-Icons sind sozusagen grafisch wirkende Schriftzeichen, die aber wie normaler Text behandelt werden (denn es sind ja Textzeichen) und damit eine schnellere und leichtere Formatierung gegenüber grafischen Icons per Bildformat (z.b. gif, jpg oder png) ermöglichen. Wir haben eine der beliebtesten Icon-Schriften in dieser Vorlage bereits anbei. Sie heißt "Fontawesome".

Font Awesome

Viele weitere Icons sind möglich, denn die Icon-Schrift "FontAwesome" ist ja bereits in dieser Vorlage installiert. So fügen Sie ggfls. weitere Icons hinzu oder ersetzen die vorhandenen.

Die Dateien der Icon-Schrift sind also bereits diesem Template beigefügt mit dem großen Vorteil, das die Icons somit auch geladen und angezeigt werden, wenn keine Internet-Verbindung besteht.

Die Icon-Schrift kann aber statt dessen auch noch einfacher durch einen entsprechenden Link im Kopfbereich der Seite aufgerufen werden, die Schrift wird dann serverseitig geladen, sehen Sie hierzu die Erklärungen auf der Seite des Anbieters. Dies mag für manche der leichtere Weg sein, falls man ein Versions-Update aktualisieren möchte. Aber wie gesagt: Besteht keine Internet-Verbindung, so wird in diesem Fall auch kein Icon angezeigt.

Wir haben die Icons schon für Sie angepasst. Denn ohne weitere Bearbeitung sind die Font-Icons immer genauso groß und erscheinen in gleicher Farbe wie die aktuell verwendete Schrift für den Text.

Als Beispiel: