Zum Hauptinhalt springen

Ihre Meinung ist uns wichtig! Gemeinsam mit Ihnen möchten wir KoliBri stetig verbessern. Teilen Sie uns Ihre Ideen, Wünsche oder Anregungen mit – schnell und unkompliziert.

InputEmail

Diese Dokumentation wird aktuell überarbeitet und befindet sich im Beta-Status. Inhalte können sich noch ändern.
Diese Komponente wird erneut auf Barrierefreiheit getestet. Der vollständige Test steht noch aus und kann erst nach einem abgeschlossenen Release erfolgen.

Synonyme: E-Mail-Eingabe, Elektronische Post, Mail

Beschreibung: Die InputEmail-Komponente ist ein spezialisiertes Eingabefeld für E-Mail-Adressen. Sie ermöglicht die sichere Erfassung einer oder mehrerer E-Mail-Adressen und unterstützt Validierung, Zeichenbegrenzung sowie barrierefreie Bedienung durch Tastatur und Screenreader.

Beispiel

Darstellung der Komponente ohne optional gesetzte Felder.

<KolInputEmail _label="E-Mail-Adresse" />

Barrierefreiheit

  • Label-Pflicht: Jedes InputEmail-Feld muss über das Attribut _label eine sichtbare Beschriftung erhalten. Dies gewährleistet, dass Screenreader-Nutzer verstehen, welchen Zweck das Eingabefeld erfüllt.
  • Hinweistexte: Mit _hint können zusätzliche Informationen bereitgestellt werden, die für alle Nutzer zugänglich sind.
  • Fehlermeldungen: Validierungsfehler können über _msg mit aussagekräftigen Meldungen gekennzeichnet werden. Browser-seitige Validierungen werden über die Attribute _touched und _msg kommuniziert.
  • Zeichenzähler: Bei aktiviertem Zeichenzähler (_has-counter) wird der Status mit einer Verzögerung von 500 ms aktualisiert, um Screenreader nicht bei jeder Eingabe zu unterbrechen. Zusätzlich wird ein versteckter, nur für assistive Technologien sichtbarer Text eingeblendet (z.B. „Sie können bis zu 100 Zeichen eingeben").
  • Fokusmanagement: Das Eingabefeld ist vollständig über die Tastatur bedienbar und bietet klare Fokusindikatoren.
  • Mehrfach-Modus: Wenn das Attribut _multiple gesetzt ist, wird die Erwartung kommuniziert, dass mehrere E-Mail-Adressen (kommagetrennt) eingegeben werden können.

Verwendung

Tastatursteuerung

TasteFunktion
TabFokussiert das Eingabefeld oder wechselt zum nächsten.
Shift + TabWechselt zum vorherigen interaktiven Element.
Pfeil-TastenNavigation innerhalb des Textinhalts.
Pos1Springt zum Anfang des Textinhalts.
EndeSpringt zum Ende des Textinhalts.
Strg + AMarkiert den gesamten Text.

Best Practices / Empfehlungen

  • Klare Labels verwenden: Geben Sie aussagekräftige Beschriftungen an, z.B. „E-Mail-Adresse", „Empfänger" oder „Registrierungs-E-Mail".
  • Hilfetexte bei Mehrfach-Eingabe: Wenn _multiple aktiviert ist, klären Sie über _hint auf, dass mehrere Adressen kommagetrennt eingegeben werden.
  • id und name setzen: Achten Sie darauf, id und _name korrekt zu setzen, damit die Daten beim Formulare-Absenden mitgesendet werden.
  • Placeholder sparsam nutzen: Verwenden Sie _placeholder nur als Zusatzhilfe, nicht für zentrale Informationen.
  • Validierungsfeedback: Höhe auf Browser-Validierung verlassen (Format-Check) und zusätzliche Hinweise über _msg geben, falls erforderlich.
  • Richtige Komponente wählen: Für Text-Eingaben verwenden Sie die ; InputEmail ist spezifisch für E-Mail-Adressen.

Anwendungsfälle

  • Registrierungsformulare und Kontoerstellung
  • Newsletter-Anmeldungen
  • Kontaktformulare und Support-Anfragen
  • Mehrfach-Adressaten in E-Mail-Versand-Formularen
  • Benachrichtigungseinstellungen
  • Benutzerprofil-Bearbeitung

FAQ

Kann die Komponente E-Mail-Adressen validieren?
Die Komponente nutzt die native Browser-Validierung für das type="email"-Format. Eine darüber hinausgehende Validierung (z.B. Prüfung auf Existenz) muss auf Serverseite erfolgen.

Wie trenne ich mehrere E-Mail-Adressen?
Mit _multiple="true" können Nutzer mehrere Adressen durch Kommata getrennt eingeben (z.B. mail1@example.com, mail2@example.com).

Wie wird die Validierung dem Nutzer angezeigt?
Nutzen Sie die Kombination aus _touched="true" (um anzuzeigen, dass das Feld bearbeitet wurde) und _msg (um eine aussagekräftige Fehlermeldung zu zeigen).

Konstruktion / Technik

Playground

Testen Sie die verschiedenen Eigenschaften des InputEmail-Felds:

Icons
Message
Tooltip Align
<KolInputEmail _label="E-Mail-Adresse" />

Funktionalitäten (mit Code)

Basis-Eingabefeld

Standard-E-Mail-Eingabe mit Label:

<KolInputEmail _label="E-Mail-Adresse" />

Mehrfach-Eingabe

Mit _multiple werden mehrere E-Mail-Adressen akzeptiert, kommagetrennt:

<KolInputEmail _hint="Adressen durch Kommas trennen" _label="E-Mail-Adressen" _multiple={true} />

Placeholder und Hinweis

Hilfstexte für bessere Usability:

<KolInputEmail _hint="Wir verwenden Ihre E-Mail für Benachrichtigungen." _label="E-Mail-Adresse" _placeholder="beispiel@domain.de" />

Formularattribute

Standard-Attribute für Formulare:

Tooltip Align
<KolInputEmail _label="E-Mail-Adresse" />

Verfügbare Attribute:

  • _disabled: Deaktiviert das Eingabefeld (mit Begründung verwenden!)
  • _readOnly: Verhindert die Bearbeitung des Feldes
  • _required: Kennzeichnet Pflichtfelder
  • _hideLabel: Blendet das Label visuell aus (bleibt für assistive Technologien sichtbar)
  • _hideMsg: Blendet die Fehlermeldung visuell aus, hält sie aber im DOM für aria-describedby
  • _shortKey: Fügt einen visuellen Shortcut-Hinweis nach dem Label hinzu und liest ihn für Screenreader vor
  • _tooltipAlign: Legt fest, wo der Tooltip bevorzugt angezeigt wird ('top' | 'right' | 'bottom' | 'left')

Icons

Icons können links und/oder rechts vom Eingabefeld angezeigt werden:

Icons
<KolInputEmail _icons={{"left":"kolibri","right":"fa-solid fa-envelope"}} _label="E-Mail-Adresse" />

Name und ID

Technische Kennzeichnung für Formulare:

<KolInputEmail _label="E-Mail-Adresse" _name="email" />

Hinweis: _name wird als HTML-Attribut name verwendet und ist wichtig für das Absenden des Formulars.

Auto-Vervollständigung und Vorschläge

Mit _autoComplete steuern Sie, ob der Browser Eingabevorschläge anzeigen soll. Der Standardwert ist 'off'. Für Felder, bei denen Browser-Autofill erwünscht ist, setzen Sie _autoComplete="email".

Mit _suggestions können Sie eine Liste von Vorschlagswerten bereitstellen, die dem Nutzer während der Eingabe als auswählbare Datenliste angezeigt werden:

<KolInputEmail _autoComplete="email" _label="E-Mail-Adresse" />

Zeichenbegrenzung und Zeichenzähler

Mit den Attributen _max-length, _max-length-behavior und _has-counter lässt sich die Eingabelänge flexibel begrenzen:

<KolInputEmail _hasCounter={true} _label="E-Mail-Adresse" _maxLength={100} />
Attribute
AttributTypStandardBeschreibung
_has-counterbooleanfalseGlobaler Schalter für den Zeichenzähler. Nur wenn dieses Attribut gesetzt (= true) ist, wird überhaupt ein Zähler ausgegeben.
_max-lengthnumberMaximale Anzahl erlaubter Zeichen. Wirksam nur, wenn _has-counter aktiv ist.
_max-length-behavior"hard" | "soft""hard"Legt fest, wie die Grenze behandelt wird, falls _max-length gesetzt ist:
- hard: Setzt zusätzlich das native maxlength‑Attribut und verhindert weitere Eingaben.
- soft: Lässt weitere Eingaben zu; der Zähler zeigt verbleibende oder überschrittene Zeichen an.
Ausgabevarianten
Fall_has-counter_max-length_max-length-behaviorSichtbarer Text
1(leer) oder false— (kein Zähler)
2true(leer)n Zeichen
3true100(leer) oder hardn/100 Zeichen
4true100softnoch 50 Zeichen verfügbar
(bzw. 5 Zeichen zu viel)

Hinweis: Wird _max-length-behavior="soft" verwendet, wird das native maxlength-Attribut nicht gesetzt – das Eingabefeld wird also nicht hart begrenzt.

Barrierefreiheit des Zeichenzählers
  • Der Zähler aktualisiert sich mit einer Verzögerung von 500 ms, damit Screenreader-Ereignisse gebündelt werden und das Tippen nicht unterbrechen.
  • Für Screenreader wird zusätzlich ein versteckter, nur für assistive Technologien sichtbarer Text eingeblendet, etwa: „Sie können bis zu 100 Zeichen eingeben."

Fehlermeldung und Validierung

Fehlerhafte Eingaben können über _msg mit aussagekräftigen Meldungen versehen werden. Mit _pattern lässt sich zusätzlich ein reguläres Ausdrucks-Muster zur Eingabevalidierung hinterlegen:

Message
<KolInputEmail _label="E-Mail-Adresse" _msg={{"_description":"Bitte geben Sie eine gültige E-Mail-Adresse ein."}} _touched={true} />

Events

Zur Behandlung von Events bzw. Callbacks siehe .

EventAuslöserValue
clickEingabefeld wird angeklickt
focusEingabefeld wird fokussiert
blurEingabefeld verliert Fokus
inputWert wird durch Eingabe geändertAktueller Wert des Eingabefelds
changeEingabe wurde abgeschlossenAktueller Wert des Eingabefelds

API

Overview

The Email input type creates an input field for email addresses. It supports built-in format validation, multiple addresses via the _multiple property, and auto-complete suggestions.

Properties

PropertyAttributeDescriptionTypeDefault
_accessKey_access-keyDefines the key combination that can be used to trigger or focus the component's interactive element.string | undefinedundefined
_autoComplete_auto-completeDefines whether the input can be auto-completed.string | undefined'off'
_disabled_disabledMakes the element not focusable and ignore all events.boolean | undefinedfalse
_hasCounter_has-counterShows a character counter for the input element.boolean | undefinedfalse
_hideLabel_hide-labelHides the caption by default and displays the caption text with a tooltip when the interactive element is focused or the mouse is over it.boolean | undefinedfalse
_hideMsg_hide-msgHides the error message but leaves it in the DOM for the input's aria-describedby.boolean | undefinedfalse
_hint_hintDefines the hint text.string | undefined''
_icons_iconsDefines the icon classnames (e.g. _icons="fa-solid fa-user").string | undefined | { right?: IconOrIconClass | undefined; left?: IconOrIconClass | undefined; }undefined
_label (required)_labelDefines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.). Set to false to enable the expert slot.stringundefined
_maxLength_max-lengthDefines the maximum number of input characters.number | undefinedundefined
_maxLengthBehavior_max-length-behaviorDefines the behavior when maxLength is set. 'hard' sets the maxlength attribute, 'soft' shows a character counter without preventing input."hard" | "soft" | undefined'hard'
_msg_msgDefines the properties for a message rendered as Alert component.Omit<AlertProps, "_on" | "_variant" | "_hasCloser" | "_label" | "_level"> & { _description: string; } | string | undefinedundefined
_multiple_multipleMakes the input accept multiple inputs.boolean | undefinedfalse
_name_nameDefines the technical name of an input field.string | undefinedundefined
_on--Gibt die EventCallback-Funktionen für das Input-Event an.InputTypeOnBlur & InputTypeOnClick & InputTypeOnChange & InputTypeOnFocus & InputTypeOnInput & InputTypeOnKeyDown | undefinedundefined
_pattern_patternDefines a validation pattern for the input field.string | undefinedundefined
_placeholder_placeholderDefines the placeholder for input field. To be shown when there's no value.string | undefinedundefined
_readOnly_read-onlyMakes the input element read only.boolean | undefinedfalse
_required_requiredMakes the input element required.boolean | undefinedfalse
_shortKey_short-keyAdds a visual shortcut hint after the label and instructs the screen reader to read the shortcut aloud.string | undefinedundefined
_smartButton_smart-buttonAllows to add a button with an arbitrary action within the element (_hide-label only).string | undefined | { _label: string; } & { _on?: ButtonCallbacksPropType<StencilUnknown> | undefined; _type?: "button" | "reset" | "submit" | undefined; _ariaExpanded?: boolean | undefined; _tabIndex?: number | undefined; _value?: StencilUnknown; _accessKey?: string | undefined; _role?: "tab" | "treeitem" | undefined; _ariaControls?: string | undefined; _ariaDescription?: string | undefined; _ariaSelected?: boolean | undefined; _customClass?: string | undefined; _disabled?: boolean | undefined; _hideLabel?: boolean | undefined; _icons?: IconsPropType | undefined; _id?: string | undefined; _inline?: boolean | undefined; _name?: string | undefined; _shortKey?: string | undefined; _syncValueBySelector?: string | undefined; _tooltipAlign?: AlignPropType | undefined; _variant?: string | undefined; }undefined
_suggestions_suggestionsSuggestions to provide for the input.W3CInputValue[] | string | undefinedundefined
_tooltipAlign_tooltip-alignDefines where to show the Tooltip preferably: top, right, bottom or left."bottom" | "left" | "right" | "top" | undefined'top'
_touched_touchedShows if the input was touched by a user.boolean | undefinedfalse
_value_valueDefines the value of the element.string | undefinedundefined

Methods

click

click() => Promise<void>

Clicks the primary interactive element inside this component.

Returns

Type: Promise<void>

focus() => Promise<void>

Sets focus on the internal element.

Returns

Type: Promise<void>

getValue() => Promise<string | undefined>

Returns the current value.

Returns

Type: Promise<string | undefined>

Slots

SlotDescription
The label of the input field.

AttributTypStandardBeschreibung
_has-counterbooleanfalseGlobaler Schalter für den Zeichenzähler. Nur wenn dieses Attribut gesetzt (= true) ist, wird überhaupt ein Zähler ausgegeben.
_max-lengthnumberMaximale Anzahl erlaubter Zeichen. Wirksam nur, wenn _has-counter aktiv ist.
_max-length-behavior"hard" | "soft""hard"Legt fest, wie die Grenze behandelt wird, falls _max-length gesetzt ist:
- hard: Setzt zusätzlich das native maxlength‑Attribut und verhindert weitere Eingaben.
- soft: Lässt weitere Eingaben zu; der Zähler zeigt verbleibende oder überschrittene Zeichen an.

Verwendung _msg

Fall_msg-Wert
Keine Messageundefined
"Standard"-Fehlermeldungstring
Meldung{_type: 'success', _description: 'Erfolgs-Meldung'}

Beispiele