CSS - Pseudoklassen
CSS-Pseudoklassen werden verwendet, um einigen Selektoren Spezialeffekte hinzuzufügen. Sie müssen kein JavaScript oder ein anderes Skript verwenden, um diese Effekte zu verwenden. Eine einfache Syntax von Pseudoklassen lautet wie folgt:
selector:pseudo-class {property: value}
CSS-Klassen können auch mit Pseudoklassen verwendet werden -
selector.class:pseudo-class {property: value}
Die am häufigsten verwendeten Pseudoklassen sind wie folgt:
Sr.Nr. | Wert & Beschreibung |
---|---|
1 | :link Verwenden Sie diese Klasse, um einem nicht besuchten Link einen besonderen Stil hinzuzufügen. |
2 | :visited Verwenden Sie diese Klasse, um einem besuchten Link einen besonderen Stil hinzuzufügen. |
3 | :hover Verwenden Sie diese Klasse, um einem Element einen besonderen Stil hinzuzufügen, wenn Sie mit der Maus darüber fahren. |
4 | :active Verwenden Sie diese Klasse, um einem aktiven Element einen besonderen Stil hinzuzufügen. |
5 | :focus Verwenden Sie diese Klasse, um einem Element einen besonderen Stil hinzuzufügen, während das Element den Fokus hat. |
6 | :first-child Verwenden Sie diese Klasse, um einem Element, das das erste untergeordnete Element eines anderen Elements ist, einen besonderen Stil hinzuzufügen. |
7 | :lang Verwenden Sie diese Klasse, um eine Sprache anzugeben, die in einem angegebenen Element verwendet werden soll. |
Beim Definieren von Pseudoklassen in einem <style> ... </ style> -Block sollten folgende Punkte beachtet werden:
a: hover MUSS nach a: link und a: in der CSS-Definition stehen, um effektiv zu sein.
a: active MUSS nach a: hover in der CSS-Definition kommen, um effektiv zu sein.
Pseudoklassennamen unterscheiden nicht zwischen Groß- und Kleinschreibung.
Pseudoklassen unterscheiden sich von CSS-Klassen, können jedoch kombiniert werden.
Die: Link Pseudo-Klasse
Das folgende Beispiel zeigt, wie Sie mit der Link- Klasse die Link-Farbe festlegen. Mögliche Werte können beliebige Farbnamen in einem gültigen Format sein.
<html>
<head>
<style type = "text/css">
a:link {color:#000000}
</style>
</head>
<body>
<a href = "">Black Link</a>
</body>
</html>
Es wird der folgende schwarze Link erzeugt -
Die: besuchte Pseudoklasse
Das folgende Beispiel zeigt, wie Sie mit der besuchten Klasse die Farbe der besuchten Links festlegen. Mögliche Werte können beliebige Farbnamen in einem gültigen Format sein.
<html>
<head>
<style type = "text/css">
a:visited {color: #006600}
</style>
</head>
<body>
<a href = "">Click this link</a>
</body>
</html>
Dies erzeugt folgenden Link. Sobald Sie auf diesen Link klicken, ändert sich seine Farbe in Grün.
Die: Schwebepseudoklasse
Das folgende Beispiel zeigt, wie Sie mit der Klasse : hover die Farbe von Links ändern, wenn Sie einen Mauszeiger über diesen Link bewegen. Mögliche Werte können beliebige Farbnamen in einem gültigen Format sein.
<html>
<head>
<style type = "text/css">
a:hover {color: #FFCC00}
</style>
</head>
<body>
<a href = "">Bring Mouse Here</a>
</body>
</html>
Es wird der folgende Link erzeugt. Jetzt bewegen Sie Ihre Maus über diesen Link und Sie werden sehen, dass er seine Farbe in Gelb ändert.
Die: aktive Pseudoklasse
Das folgende Beispiel zeigt, wie Sie mit der Klasse : active die Farbe aktiver Links ändern. Mögliche Werte können beliebige Farbnamen in jedem gültigen Format sein.
<html>
<head>
<style type = "text/css">
a:active {color: #FF00CC}
</style>
</head>
<body>
<a href = "">Click This Link</a>
</body>
</html>
Es wird der folgende Link erzeugt. Wenn ein Benutzer darauf klickt, ändert sich die Farbe in Pink.
Die: Fokus-Pseudoklasse
Das folgende Beispiel zeigt, wie Sie mit der Klasse : focus die Farbe fokussierter Links ändern. Mögliche Werte können beliebige Farbnamen in einem gültigen Format sein.
<html>
<head>
<style type = "text/css">
a:focus {color: #0000FF}
</style>
</head>
<body>
<a href = "">Click this Link</a>
</body>
</html>
Es wird der folgende Link erzeugt. Wenn dieser Link fokussiert wird, ändert sich seine Farbe in Orange. Die Farbe ändert sich zurück, wenn der Fokus verloren geht.
Die: Pseudoklasse des ersten Kindes
Die Pseudoklasse : first-child entspricht einem angegebenen Element, das das erste untergeordnete Element eines anderen Elements ist, und fügt dem Element, das das erste untergeordnete Element eines anderen Elements ist, einen besonderen Stil hinzu.
Um dies zu erreichen, muss die Arbeit des ersten Kindes im IE <! DOCTYPE> oben im Dokument deklariert werden.
Um beispielsweise den ersten Absatz aller <div> -Elemente einzurücken, können Sie diese Definition verwenden:
<html>
<head>
<style type = "text/css">
div > p:first-child {
text-indent: 25px;
}
</style>
</head>
<body>
<div>
<p>First paragraph in div. This paragraph will be indented</p>
<p>Second paragraph in div. This paragraph will not be indented</p>
</div>
<p>But it will not match the paragraph in this HTML:</p>
<div>
<h3>Heading</h3>
<p>The first paragraph inside the div. This paragraph will not be effected.</p>
</div>
</body>
</html>
Es wird das folgende Ergebnis erzeugt -
Die: lang Pseudoklasse
Die Sprachpseudoklasse : lang ermöglicht das Erstellen von Selektoren basierend auf der Spracheinstellung für bestimmte Tags.
Diese Klasse ist nützlich in Dokumenten, die mehrere Sprachen ansprechen müssen, die für bestimmte Sprachkonstrukte unterschiedliche Konventionen haben. Beispielsweise verwendet die französische Sprache normalerweise spitze Klammern (<und>) für Anführungszwecke, während die englische Sprache Anführungszeichen ('und') verwendet.
In einem Dokument, das diesen Unterschied beheben muss, können Sie die Pseudoklasse: lang verwenden, um die Anführungszeichen entsprechend zu ändern. Der folgende Code ändert das <blockquote> -Tag entsprechend der verwendeten Sprache:
<html>
<head>
<style type = "text/css">
/* Two levels of quotes for two languages*/
:lang(en) { quotes: '"' '"' "'" "'"; }
:lang(fr) { quotes: "<<" ">>" "<" ">"; }
</style>
</head>
<body>
<p>...<q lang = "fr">A quote in a paragraph</q>...</p>
</body>
</html>
Die Selektoren: lang gelten für alle Elemente im Dokument. Da jedoch nicht alle Elemente die Anführungszeichen-Eigenschaft verwenden, ist der Effekt für die meisten Elemente transparent.
Es wird das folgende Ergebnis erzeugt -