Badge-Komponente: Barrierefreiheit
Diese Dokumentation beschreibt die Barrierefreiheitsfunktionen der Badge-Komponente und gibt Hinweise zur korrekten Verwendung für eine optimale Zugänglichkeit.
ARIA-Attribute und Rollen
Die Badge-Komponente verwendet folgende ARIA-Attribute und Rollen, um die Barrierefreiheit zu verbessern:
Badge-Container
role="status": Identifiziert die Badge als Statusanzeigearia-label="...": Beschreibt die Badge für Screenreaderid="badge-[unique-id]": Eindeutige ID für ARIA-Referenzen
Daten-Attribute
data-variant="default|primary|success|warning|error|info": Gibt die Variante der Badge andata-size="xs|sm|md|lg": Gibt die Größe der Badge andata-counter="true": Kennzeichnet die Badge als Zählerdata-dot="true": Kennzeichnet die Badge als Punkt
Icon
aria-hidden="true": Versteckt das Icon vor Screenreadern
Screenreader-Unterstützung
Die Badge-Komponente bietet folgende Screenreader-Unterstützungen:
- Beschreibende Labels: Die Badge wird mit einem beschreibenden Label versehen, das den Inhalt oder den Status beschreibt
- Zähler-Ankündigungen: Zähler-Badges werden mit Kontext angekündigt (z.B. "5 Benachrichtigungen")
- Status-Ankündigungen: Punkt-Badges werden mit ihrem Status angekündigt (z.B. "Fehlerstatus")
Beispiele für barrierefreie Verwendung
Standard-Badge
<Badge>Neu</Badge>
Der Screenreader wird "Neu" ankündigen.
Badge mit Icon
<Badge icon={<Icon />}>Mit Icon</Badge>
Der Screenreader wird "Mit Icon" ankündigen, das Icon wird ignoriert.
Zähler-Badge
<Badge isCounter>5</Badge>
Der Screenreader wird "5 Benachrichtigungen" ankündigen.
Punkt-Badge
<Badge isDot variant="error" />
Der Screenreader wird "Fehlerstatus" ankündigen.
Badge mit benutzerdefinierter ID
<Badge id="notification-badge" isCounter>3</Badge>
Best Practices
-
Beschreibende Inhalte: Verwenden Sie beschreibende Inhalte für Badges
- Gut:
<Badge>Neu</Badge>oder<Badge>Beta</Badge> - Schlecht:
<Badge>X</Badge>oder<Badge>!</Badge>
- Gut:
-
Zähler mit Kontext: Verwenden Sie
isCounterfür Badges, die Zahlen anzeigen- Dies f ügt automatisch den Kontext "Benachrichtigungen" hinzu
-
Status-Punkte mit Variante: Verwenden Sie die passende Variante für Punkt-Badges
variant="success"für positive Statusvariant="error"für negative Statusvariant="warning"für Warnungenvariant="info"für Informationen
-
Konsistente Größen: Verwenden Sie konsistente Größen für Badges in ähnlichen Kontexten
- Dies verbessert die visuelle Konsistenz und Benutzererfahrung
-
Ausreichender Kontrast: Stellen Sie sicher, dass die Badge ausreichenden Kontrast zum Hintergrund hat
- Die Komponente verwendet automatisch kontrastreiche Farbkombinationen
Bekannte Einschränkungen
- Komplexe Inhalte: Wenn die Badge komplexe Inhalte enthält (z.B. mehrere Elemente), sollte ein benutzerdefiniertes
aria-labelüberhtmlPropsbereitgestellt werden - Dynamische Badges: Bei dynamisch aktualisierten Badges sollte ein
aria-live="polite"überhtmlPropshinzugefügt werden