Zum Hauptinhalt springen

Data Binding

In ChatGPT öffnen

webforJ beinhaltet eine Datenbindung-Funktion, die UI-Komponenten mit Backend-Datenmodellen in Java-Anwendungen integriert. Diese Funktion schließt die Lücke zwischen der UI und der Datenschicht, sodass Änderungen in der UI sich im Datenmodell widerspiegeln und umgekehrt, wodurch die Komplexität der Ereignisverarbeitung und Daten-synchronisierung verringert wird.

Konzept

Die folgende Demonstration zeigt eine einfache webforJ-App zur Registrierung von Superhelden unter Verwendung der webforJ-Datenbindung. Die App besteht aus zwei Hauptteilen: HeroRegistration.java und Hero.java.

In HeroRegistration.java konfiguriert der Code die Benutzeroberfläche mit einem TextField zum Eingeben des Namens des Helden, einer ComboBox zur Auswahl einer Superkraft und einem Button, um die Registrierung abzusenden.

Die Klasse Hero definiert das Datenmodell mit Validierungseinschränkungen für den Namen und die Kraft des Helden. Die Eingaben müssen gültig sein und bestimmten Kriterien wie Länge und Muster entsprechen.

Die App verwendet den BindingContext, um UI-Komponenten an die Eigenschaften des Hero-Objekts zu binden. Wenn ein Benutzer auf den Absenden-Button klickt, schreibt die App die im Formular eingegebenen Daten zurück in das Hero-Bean, sofern sie gültig sind.

public class HeroRegistration extends App {

private TextField name = new TextField("Text Field");
private ComboBox power = new ComboBox("Power");
private Button submit = new Button("Submit Application");
private FlexLayout layout = FlexLayout.create(name, power, submit).vertical().build()
.setStyle("margin", "20px auto").setMaxWidth("400px");

@Override
public void run() throws WebforjException {
power.insert("Fly", "Invisible", "LaserVision", "Speed", "Teleportation");

BindingContext<Hero> context = BindingContext.of(this, Hero.class, true);
Hero bean = new Hero("Superman", "Fly");

// reflect the bean data in the form
context.read(bean);

submit.onClick(e -> {
// write the form data back to the bean
ValidationResult results = context.write(bean);

if (results.isValid()) {
// do something with the bean
// repository.persist(bean)
}
});

Frame frame = new Frame();
frame.add(layout);
}
}

Hauptmerkmale

  • Bidirektionale Bindung: Unterstützt bidirektionale Datenbindung, die es Änderungen im Datenmodell ermöglicht, die UI zu aktualisieren, und Benutzereingaben in der UI, das Datenmodell zu aktualisieren.

  • Unterstützung für Validierung: Integriert umfassende Validierungsmechanismen, die Sie anpassen und erweitern können. Entwickler können ihre eigenen Validierungsregeln implementieren oder vorhandene Validierungsframeworks wie Jakarta Validation verwenden, um die Datenintegrität vor der Aktualisierung des Modells zu überprüfen.

  • Erweiterbarkeit: Kann leicht erweitert werden, um verschiedene Arten von UI-Komponenten, Datenumwandlungen und komplexe Validierungsszenarien zu unterstützen.

  • Annotierungsgetriebene Konfiguration: Verwendet Annotations, um Boilerplate-Code zu minimieren und die Bindungen zwischen UI-Komponenten und Datenmodellen deklarativ und leicht zu verwalten.

Themen

In ChatGPT öffnen