2013-12-28 02:15:25 +01:00
---
language: css
contributors:
- ["Mohammad Valipour", "https://github.com/mvalipour"]
translators:
- ["Kyr", "http://github.com/kyrami"]
lang: de-de
---
In den frühen Tagen des Internets gab es keine visuellen Elemente, alles war nur reiner Text. Aber mit der Weiterentwickliung von Browsern wurden auch vollständig visuelle Webseiten zu einem Standard.
CSS ist die allgemeine Sprache, die dazu da ist, damit man den HTML-Code und die Designelemente von Webseiten (strikt) unterscheiden kann.
Kurzgefasst, CSS ermöglicht es, verschiedene HTML-Elemente anzuvisieren und ihnen stilistische Eigenschaften zu geben.
CSS hat wie jede andere Sprache viele Versionen. Hier fokussieren wir uns auf CSS2.0, welche nicht die neueste, aber die am weitesten verbreitete und unterstützte Version ist.
**NOTE:** Weil die Ausgabe von CSS visuelle Eigenschaften sind, wirst du wahrscheinlich einen CSS-Playground wie [dabblet ](http://dabblet.com/ ) benutzen müssen, um die Sprache richtig zu lernen.
In diesem Artikel wird am meisten auf generelle Hinweise und die Syntax geachtet.
```css
/* kommentare werden in sternchen-schrägstrichkombinationen gepackt (genauso wie hier!) */
/* ####################
## SELEKTOREN
####################*/
/* Eigentlich ist die häufigste Anwendungsweise von CSS sehr simpel */
selektor { eigenschaft: wert; /* mehr eigenschaften...*/ }
/* der selektor wird dazu benutzt, ein element auf der seite anzuvisieren
Aber man kann auch alle Elemente auf einer Seite anvisieren! */
* { color:red; } /* farbe:rot */
/*
Wenn wir so ein Element auf einer Seite haben:
< div class = 'eine-klasse klasse2' id = 'eineId' attr = 'wert' / >
*/
/* kann man es so bei seiner klasse anvisieren */
.eine-klasse { }
/*oder bei beiden klassen! */
.eine-klasse.klasse2 { }
/* oder beim namen des tags */
div { }
/* oder bei seiner id */
#eineId { }
/* oder daran, dass es ein Attribut hat! */
[attr] { font-size:smaller; }
/* oder daran, dass das attribut einen bestimmten wert hat*/
[attr='wert'] { font-size:smaller; }
/* beginnt mit einem wert*/
[attr^='wert'] { font-size:smaller; }
/* oder endet mit */
[attr$='rt'] { font-size:smaller; }
/* oder sogar nur beinhaltet */
[attr~='er'] { font-size:smaller; }
2013-12-28 02:17:04 +01:00
/* was aber noch wichtiger ist, ist dass man alle diese kombinieren
kann - man sollte nur mit der leerzeichensetzung vorsichtig sein,
da es mit einem leerzeichen zwei verschiedene selektoren wären*/
2013-12-28 02:15:25 +01:00
div.eine-klasse[attr$='rt'] { } /* so ist es richtig */
2014-01-02 17:30:48 +01:00
/* man kann auch ein element daran festmachen, wie sich die übergeordneten
elemente verhalten!*/
2013-12-28 02:15:25 +01:00
/*es muss allerdings ein direktes kind sein */
2014-01-02 17:30:48 +01:00
div.ein-elternteil > .klassen-name {}
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
/* oder jeder seiner eltern in der struktur */
/* das folgende heißt also dass jedes element mit der klasse 'klassen-name' und dem
elternteil IN JEDER TIEFE ausgewählt wird */
div.ein-elternteil .klassen-name {}
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
/* achtung: dasselbe ohne das leerzeichen hat eine andere bedeutung
kannst du mir sagen, was? */
div.ein-elternteil.klassen-name {}
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
/* man kann auch ein element nach seinem direkten vorherigen zwilling
auswählen */
.ich-bin-vorher + .dieses-element { }
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
/*oder jeden zwilling davor */
.ich-kann-jeder-davor-sein ~ .dieses-element {}
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
/* es gibt ein paar pseudoklassen, die sich basierend auf dem
seitenverhalten, nämlich nicht auf der seitenstruktur auswählen
lassen können */
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
/* zum beispiel, wenn über ein element mit dem mauszeiger gefahren wird */
2013-12-28 02:15:25 +01:00
:hover {}
2014-01-02 17:30:48 +01:00
/* oder eine bereits besuchten link*/
2013-12-28 02:15:25 +01:00
:visited {}
2014-01-02 17:30:48 +01:00
/* oder einen noch nicht besuchten link*/
2013-12-28 02:15:25 +01:00
:link {}
2014-01-02 17:30:48 +01:00
/* oder ein eingabeelement, das zurzeit im fokus steht */
2013-12-28 02:15:25 +01:00
:focus {}
/* ####################
2014-01-02 17:30:48 +01:00
## EIGENSCHAFTEN
2013-12-28 02:15:25 +01:00
####################*/
selector {
2014-01-02 17:30:48 +01:00
/* einheiten */
width: 50%; /* in prozent */
font-size: 2em; /* mal der derzeitigen schriftgröße */
width: 200px; /* in pixeln */
font-size: 20pt; /* in punkten */
width: 5cm; /* in zentimetern */
width: 50mm; /* in millimetern */
width: 5in; /* in zoll */
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
/* farben */
background-color: #F6E /* in kurzem hex */
background-color: #F262E2 /* in langem hex */
background-color: tomato /* kann auch eine genannte farbe sein */
2013-12-28 02:15:25 +01:00
background-color: rgb(255, 255, 255) /* in rgb */
2014-01-02 17:30:48 +01:00
background-color: rgb(10%, 20%, 50%) /* in rgb prozent */
background-color: rgba(255, 0, 0, 0.3); /* in semi-transparentem rgb */
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
/* bilder */
2013-12-28 02:15:25 +01:00
background-image: url(/path-to-image/image.jpg);
2014-01-02 17:30:48 +01:00
/* schriften */
2013-12-28 02:15:25 +01:00
font-family: Arial;
2014-01-02 17:30:48 +01:00
font-family: "Courier New"; /* wenn der name ein leerzeichen beinhält, kommt er in
gänsefüßchen */
font-family: "Courier New", Trebuchet, Arial; /* wenn der erste nicht gefunden wird, wird
der zweite benutzt und so weiter */
2013-12-28 02:15:25 +01:00
}
```
2014-01-02 17:30:48 +01:00
## Benutzung
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
speichere das css, das du benutzen willst mit der endung '.css'.
2013-12-28 02:15:25 +01:00
```xml
2014-01-02 17:30:48 +01:00
<!-- du musst die css - datei im <head> - bereich der seite erwähnen -->
2013-12-28 02:15:25 +01:00
< link rel = 'stylesheet' type = 'text/css' href = 'filepath/filename.css' / >
2014-01-02 17:30:48 +01:00
<!-- es geht allerdings auch direkt, wobei diese methode nicht
empfohlen ist -->
2013-12-28 02:15:25 +01:00
< style >
selector { property:value; }
< / style >
2014-01-02 17:30:48 +01:00
<!-- oder direkt am element (sollte aber gelassen werden) -->
2013-12-28 02:15:25 +01:00
< div style = 'property:value;' >
< / div >
```
2014-01-02 17:30:48 +01:00
## Wichtigkeit
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
ein element kann von mehr als einem selektoren angezielt werden.
und kann auch eine eigenschaft mehr als einmal zugewiesen bekommen.
in diesen fällen gibt es regeln, die wichtigkeit von selektoren einführen.
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
wie haben dieses CSS:
2013-12-28 02:15:25 +01:00
```css
/*A*/
2014-01-02 17:30:48 +01:00
p.klasse1[attr='wert']
2013-12-28 02:15:25 +01:00
/*B*/
2014-01-02 17:30:48 +01:00
p.klasse1 {}
2013-12-28 02:15:25 +01:00
/*C*/
2014-01-02 17:30:48 +01:00
p.klasse2 {}
2013-12-28 02:15:25 +01:00
/*D*/
p {}
/*E*/
2014-01-02 17:30:48 +01:00
p { property: wert !important; }
2013-12-28 02:15:25 +01:00
```
2014-01-02 17:30:48 +01:00
und das folgende markup:
2013-12-28 02:15:25 +01:00
```xml
< p style = '/*F*/ property:value;' class = 'class1 class2' attr = 'value' >
< / p >
```
2014-01-02 17:30:48 +01:00
die wichtigkeit der stile ist wie folgt:
(die wichtigkeit gilt nur für **eigenschaften** , nicht für ganze blöcke)
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
* `E` hat die größte wichtigkeit wegen dem schlüsselwort `!important` .
man sollte diese form aber vermeiden.
* `F` ist als nächstes, da es direkt an dem element definiert ist.
* `A` ist als nächstes, da es "spezifischer" als alle anderen ist.
spezifischer = mehr zuweisungen: 1 tagname `p` +
klassenname `klasse1` + 1 attribut `attr='value'`
* `C` ist als nächstes obwohl es genau so ist wie `B`
aber es erscheint als letztes.
* dann ist `B`
* und als letztes `D` .
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
## Kompabilität
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
die meisten features von CSS sind in allen browsern verfügbar.
man sollte jedoch immer darauf achten, wenn man etwas mit CSS
programmiert.
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
[QuirksMode CSS ](http://www.quirksmode.org/css/ ) ist eine der besten quellen dafür.
2013-12-28 02:15:25 +01:00
2014-01-02 17:30:48 +01:00
## Weiterlesen
2013-12-28 02:15:25 +01:00
* [Understanding Style Precedence in CSS: Specificity, Inheritance, and the Cascade ](http://www.vanseodesign.com/css/css-specificity-inheritance-cascaade/ )
* [QuirksMode CSS ](http://www.quirksmode.org/css/ )
* [Z-Index - The stacking context ](https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Understanding_z_index/The_stacking_context )