Die Texte in diesem Artikel wurden teilweise mit Hilfe künstlicher Intelligenz erarbeitet und von uns korrigiert und überarbeitet. Für die Generierung wurden folgende Dienste verwendet:
Wenn du noch nicht mit der Arbeit an Formularen mit Alpine.js vertraut bist, kannst du deine Kenntnisse in unserem ersten Artikel zu diesem Thema, Interaktive Formulare mit Alpine.js, auffrischen.
In unserem ersten Artikel zu interaktiven Formularen mit Alpine.js haben wir bereits angedeutet, dass Alpine.js neben der allgemeinen Darstellung von serverseitigen Informationen im Formular auch dazu verwendet werden kann, um u.a. Einfluss auf einzelne Elemente zu nehmen.
Aufgrund der großen Nachfrage haben wir uns entschlossen, genau dieses Thema in diesem Folgeartikel aufzugreifen und beispielhaft zu zeigen, wie man mit Alpine.js Informationen und Zustände zur Validierung eines Formulars nutzen kann.
Einrichtung
Für diese Demonstration verwenden wir unsere Astro Boilerplate, die wir bereits in einem früheren Artikel ausführlich vorgestellt haben.
Download Astro BoilerplateWenn unsere Boilerplate nicht das Richtige für dich ist, ist das kein Problem. Die Schritte zur Validierung von Formulareingaben funktionieren in jedem Projekt mit Alpine.js.
Methoden für Alpine.js integrieren
Um im weiteren Verlauf der Implementierung auf die benötigten Daten und Methoden aus Alpine.js zugreifen zu können, werden diese zunächst deklariert, um im weiteren Verlauf Fehler zu vermeiden.
form.ts
form()
kontrolliert den Zustand loading
und speichert die vom Server gesendete Response
über die Methode submit()
, die beim Absenden des Formulars ausgeführt wird.
Außerdem ist eine fiktive fakeResponse()
enthalten, die beispielhafte und vereinfachte Validierungsfehler von unserem fiktiven Backend “empfängt”.
Die Response
muss ein error
Objekt enthalten, in dem jedes Schlüssel-Wert-Paar aus dem Namen des Eingabeelements und dem zugehörigen Validierungsfehler besteht.
input.ts
input.ts
übernimmt die Darstellung der Validierungsfehler für ein Eingabeelement über die Methode validate()
, die über das Attribut x-effect
eingebunden wird, um die Daten für die Darstellung beim Absenden des Formulars neu zu berechnen.
globals.ts
Abschließend werden für diesen Schritt die für Alpine.js deklarierten Methoden importiert und im EventListener alpine:init
registriert, um auf die benötigten Scopes zugreifen zu können.
Optionale Utility-Methoden deklarieren
Damit wir Namen für Eingabeelemente auch gleichzeitig als Label benutzen können, legen wir die Methode capitalize
an, welche Strings geschrieben in kebab-case (z. B.: "email-address"
) aufteilt und jedes Wort kapitalisiert.
Solltest du dich gegen die Kapitalisierung entscheiden, müssen die entsprechenden Referenzen in der Komponente
input.astro
entfernt werden
Seiten und Komponenten in Astro anlegen
Im nächsten Schritt legen wir die von uns für das Formular benötigten Seiten und Komponenten an. Hierbei definieren wir eine <Input />
Komponente und integrieren diese in den Formularblock.
input.astro
input.astro
fasst die Elemente <input />
und <label>
in einer Komponente zusammen und enthält zusätzlich die Darstellung der Validierungsfehler, die über den Alpine-Kontext input
abgebildet werden.
index.astro
index.astro
repräsentiert unseren Formularblock und verwendet die vordefinierte Komponente <Input />
und ergänzt deren Logik um den Kontext form
, so dass Fehler aus dem Objekt response
dargestellt werden können.
Während unsere Komponente <Input />
die Darstelung der Validierungsfehler handhabt, binden wir das Attribut disabled
der einzelnen Eingabeelemente and den Zustand loading
, um Mehrfachsendungen des Formulars während der Verarbeitung zu unterbinden.
TL;DR
Mit Alpine.js zeigen wir, wie Validierungsfehler aus dem Backend dynamisch in einem Formular dargestellt werden und wie Eingabeelemente auf entsprechende Ereignisse im Browser reagieren.