Einfache Darstellung von Validation im Client mit :user-valid und :user-invalid

Morris M. | Softwareentwickler
10/2024

Optimierte Formularvalidierung im Frontend

Das Pseudo-Element :user-valid und sein Gegenstück :user-invalid sind mittlerweile in allen Standardbrowsern verfügbar und werden unterstützt. Nachfolgend betrachten wir beispielhaft, wie diese neuen Klassen verwendet werden können, um die Darstellung von Validierungszuständen zu vereinfachen.

Nehmen wir für unser Beispiel ein einfaches Formular zur Dateneingabe, aufgebaut wie folgt:

<form style="display:flex; flex-direction:column; width:75ch;gap:1rem;">

    <label for="title">Titel: </label>
    <input id="title"
           name="title"
           type="text" />

    <label for="firstName">Vorname *: </label>
    <input id="firstName"
           name="firstName"
           type="text"
           required />

    <label for="lastName">Nachname *: </label>
    <input id="lastName"
           name="lastName"
           type="text"
           required />

    <label for="email">Email *: </label>
    <input id="email"
           name="email"
           type="email"
           required />

    <input type="submit" value="Absenden">
</form>

Die :user-valid-Pseudoklasse wird automatisch an jedes Input-Element angehängt, das nach seinen eigenen Regeln als „valid“ erkannt wird, genau wie das vermutlich bekanntere :valid. Im Gegensatz zu dieser allerdings wird :user-valid erst vergeben, nachdem der Benutzer mit dem Element interagiert hat, und verhindert somit, dass der Benutzer beim ersten Laden des Formulars mit Validierungsnachrichten überladen wird.

Betrachten wir dies im direkten Vergleich. Nachfolgend vergeben wir zunächst ein Styling für die bekannten :valid- und :invalid-Klassen:

input:valid {
    border: 2px solid green;
}

input:invalid {
    border: 2px solid red;
}

Wie wir sehen, wird der Benutzer mit Validierungsnachrichten geradezu erschlagen, und dabei zeigen wir noch nicht einmal Texthinweise an. Konfigurieren wir alternativ die :user-valid- und :user-invalid-Klassen:

input:user-valid {
    border: 2px solid green;
}

input:user-invalid {
    border: 2px solid red;
}

Zunächst stellt sich keine Änderung im ungestylten Formular ein.

Erst sobald wir eine Eingabe tätigen, wird das entsprechende Styling aktiv.

Wie wir sehen, werden nur die Felder aktiviert, in denen wir Eingaben getätigt haben. Ein Klicken des „Absenden“-Buttons eines Formulars zählt selbstverständlich als Interaktion mit all seinen Eingabefeldern, wie wir nachfolgend beobachten können.

Fazit

Die neuen Pseudo-Klassen sind, wie ersichtlich, ein hervorragendes Werkzeug, um eine einfachere und gleichzeitig elegantere Front-End-Validierung zu implementieren. Sie sind seit spätestens November 2023 in allen gängigen Browsern unterstützt.

No items found.
Morris M. | Softwareentwickler
Zurück zur Übersicht

Kommentare

Hinterlasse uns einen Kommentar

Wir freuen uns auf deinen Beitrag!

* Ihre Email wird nicht veröffentlicht

Thank you!

Your comment will appear above automagically ✨

Refresh Page
Oops! Something went wrong while submitting the form.

Gemeinsam Großes schaffen

Wir freuen uns auf ein kostenloses Erstgespräch mit Ihnen!
Unser Geschäftsführer Tibor Csizmadia und unser Kundenbetreuer Jens Walter stehen Ihnen persönlich zur Verfügung. Profitieren Sie von unserer langjährigen Erfahrung und erhalten Sie eine kompetente Erstberatung in einem unverbindlichen Austausch.
Foto von Tibor

Tibor Csizmadia

Geschäftsführer
Foto von Jens

Jens Walter

Projektmanager
Devware GmbH verpflichtet sich, Ihre Privatsphäre zu schützen. Wir benötigen Ihre Kontaktinformationen, um Sie bezüglich unserer Produkte und Dienstleistungen zu kontaktieren. Mit Klick auf Absenden geben Sie sich damit einverstanden. Weitere Informationen finden Sie unter Datenschutz.
Vielen Dank für Ihre Nachricht!

Wir haben Ihre Anfrage erhalten und melden uns in Kürze bei Ihnen.

Falls Sie in der Zwischenzeit Fragen haben, können Sie uns jederzeit unter Kontaktanfrage@devware.de erreichen.

Wir freuen uns auf die Zusammenarbeit!
Oops! Something went wrong while submitting the form.
KontaktImpressumDatenschutz