:visited CSS-Pseudoklasse
Baseline
Weitgehend verfügbar
Diese Funktion ist gut etabliert und funktioniert auf vielen Geräten und in vielen Browserversionen. Sie ist seit Juli 2015 browserübergreifend verfügbar.
Die :visited CSS Pseudoklasse wird angewendet, sobald der Benutzer den Link besucht hat. Aus Datenschutzgründen sind die Stile, die mit diesem Selektor geändert werden können, sehr eingeschränkt. Die :visited Pseudoklasse gilt nur für <a> und <area> Elemente, die ein href Attribut haben.
Probieren Sie es aus
p {
font-weight: bold;
}
a:visited {
color: forestgreen;
text-decoration-color: hotpink;
}
<p>Pages that you might have visited:</p>
<ul>
<li>
<a href="https://developer.mozilla.org">MDN Web Docs</a>
</li>
<li>
<a href="https://www.youtube.com/">YouTube</a>
</li>
</ul>
<p>Pages unlikely to be in your history:</p>
<ul>
<li>
<a href="https://developer.mozilla.org/missing-1">Random MDN page</a>
</li>
<li>
<a href="https://example.com/missing-1">Random Example page</a>
</li>
</ul>
Stile, die durch die :visited und nicht besuchten :link Pseudoklassen definiert werden, können durch nachfolgende Benutzeraktions-Pseudoklassen (:hover oder :active) überschrieben werden, die mindestens die gleiche Spezifität haben. Um Links angemessen zu gestalten, setzen Sie die :visited Regel nach der :link Regel, aber vor den :hover und :active Regeln, wie es durch die LVHA-Reihenfolge definiert ist: :link — :visited — :hover — :active. Die :visited Pseudoklasse und die :link Pseudoklasse schließen sich gegenseitig aus.
Datenschutzbeschränkungen
Aus Datenschutzgründen beschränken Browser streng, welche Stile Sie mit dieser Pseudoklasse anwenden können und wie sie verwendet werden können:
- Erlaubte CSS-Eigenschaften sind
color,background-color,border-color,border-bottom-color,border-left-color,border-right-color,border-top-color,column-rule-color,outline-color,text-decoration-colorundtext-emphasis-color. - Erlaubte SVG-Attribute sind
fillundstroke. - Die Alpha-Komponente der erlaubten Stile wird ignoriert. Die Alpha-Komponente des Elements im nicht-
:visitedZustand wird stattdessen verwendet. In Firefox, wenn die Alpha-Komponente0ist, wird der im:visitedgesetzte Stil vollständig ignoriert. - Obwohl diese Stile das Erscheinungsbild der Farben für den Endbenutzer ändern können, wird die Methode
window.getComputedStyleimmer lügen und den Wert der nicht-:visitedFarbe zurückgeben. - Das
<link>Element wird niemals von:visitedgetroffen. - DOM-Methoden, die Elemente über CSS-Selektoren abgleichen — wie
querySelector()undquerySelectorAll()— geben immer ein "leeres" Ergebnis zurück, auch wenn es besuchte Links im Dokument gibt. Für die genannten Methoden wird diesnulloder eine leereNodeListsein.
Hinweis: Weitere Informationen zu diesen Einschränkungen und den dahinterliegenden Gründen finden Sie in Privacy and the :visited selector.
Syntax
:visited {
/* ... */
}
Beispiele
Eigenschaften, die sonst keine Farbe haben oder transparent sind, können mit :visited nicht verändert werden. Von den Eigenschaften, die mit dieser Pseudoklasse gesetzt werden können, hat Ihr Browser wahrscheinlich nur für color und column-rule-color Standardwerte. Daher müssen Sie für die anderen Eigenschaften einen Basiswert außerhalb des :visited Selektors festlegen, wenn Sie diese ändern möchten.
HTML
<a href="#test-visited-link">Have you visited this link yet?</a><br />
<a href="">You've already visited this link.</a>
CSS
a {
/* Specify non-transparent defaults to certain properties,
allowing them to be styled with the :visited state */
background-color: white;
border: 1px solid white;
}
a:visited {
background-color: yellow;
border-color: hotpink;
color: hotpink;
}
Ergebnis
Spezifikationen
| Spezifikation |
|---|
| HTML> # selector-visited> |
| Selectors Level 4> # visited-pseudo> |
Browser-Kompatibilität
Siehe auch
- Privacy and the :visited selector
- Link-bezogene Pseudoklassen:
:link,:active,:hover