Barrierefreies/SEO-freundliches CSS-Verstecken

Avatar of Chris Coyier
Chris Coyier am
.screen-reader-text {
  position: absolute;
  top: -9999px;
  left: -9999px;
}

Diese Klasse kann ein Element von der Seite entfernen, es aus dem Fluss nehmen und verursacht keine Überlauf-Scrollbalken.

Es ist besser als display: none; oder sogar visibility: hidden;, wenn das Ziel ist, das Element visuell auszublenden, es aber für Screenreader zugänglich zu lassen.

Snook hat eine Anleitung zu einer robusteren Klasse, die mehr Situationen berücksichtigt.

.element-invisible {
  position: absolute !important;
  height: 1px; width: 1px; 
  overflow: hidden;
  clip: rect(1px 1px 1px 1px); /* IE6, IE7 */
  clip: rect(1px, 1px, 1px, 1px);
}

WordPress verwendet eine noch robustere Klasse, die berücksichtigt, dass das Element angezeigt werden sollte, falls es den Fokus erhält.

.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  word-wrap: normal !important;
}
.screen-reader-text:focus {
  background-color: #eee;
  clip: auto !important;
  clip-path: none;
  color: #444;
  display: block;
  font-size: 1em;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000; /* Above WP toolbar. */
}