Das Problem verstehen
Dieses Problem tritt auf, wenn versucht wird, Validierungsklassen auf dynamische Textfelder innerhalb einer Tabelle anzuwenden. Das Ziel besteht darin, eine Validierung dieser Textfelder durchzuführen, wenn auf die Schaltfläche „Speichern“ geklickt wird.
Lösung
Um dieses Problem zu beheben, ist es wichtig, die folgenden Schritte umzusetzen:
-
Datenval-Attribute einbeziehen: Weisen Sie dem die erforderlichen Datenval-Attribute zu Textfelder sowie Platzhalterelemente für Validierungsnachrichten. Diese Attribute sind für die clientseitige Validierung mit jquery.validate.unobtrusive.js von entscheidender Bedeutung.
-
Anfängliches Standard-ClsTargetInfo-Objekt: Beginnen Sie mit dem Hinzufügen eines Standard-ClsTargetInfo-Objekts zur TargetInfo-Eigenschaft in Ihrem Modell und Generieren Sie den HTML-Code in der Ansicht.
-
Erstellen Sie ein verstecktes Element für Indexer: Fügen Sie innerhalb der Tabellenzeile ein verstecktes Eingabeelement für den Indexer ein. Dadurch können nicht aufeinanderfolgende Indexer gepostet und an die Sammlung gebunden werden.
-
HTML-Vorlage kopieren: Überprüfen Sie den für die Tabellenzeile generierten HTML-Code. Kopieren Sie es in ein verstecktes Element außerhalb der Formular-Tags und ersetzen Sie alle Indexer durch ein Dummy-Zeichen (#).
-
Klonen und an Tabelle anhängen: Klonen Sie im JavaScript-Code die neue Zeile , aktualisieren Sie die Indexer und hängen Sie sie an die Tabelle an.
-
Reparse-Validator: Führen Sie nach dem Hinzufügen der neuen Zeile eine erneute Analyse durch der Validator verwendet $.validator.unobtrusive.parse(form).
Zusätzliche Hinweise
- Unaufdringliche Validierung basiert auf dem Parsen von Datenvalidierungsattributen die erste Darstellung des Formulars. Daher ist beim Hinzufügen dynamischer Inhalte ein erneutes Parsen erforderlich.
- Die versteckte Eingabe für den Indexer ermöglicht das Löschen jeder Zeile in der Sammlung.
- Erwägen Sie zur besseren Wartbarkeit die Verwendung von CSS anstelle von Inline-Stilen und Leistung.
- Verwenden Sie Teilansichten (BeginCollectionItem-Helfer) für eine einfachere Wartbarkeit, wenn Sie Zeilen rein auf dem Client hinzufügen Seite.
Das obige ist der detaillierte Inhalt vonWie führe ich eine clientseitige Validierung für dynamisch hinzugefügte Textfelder in einer Tabelle durch?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!