Databinding programmatisch
Da sich die UI-Komponenten in ihrer Fähigkeit Daten anzuzeigen zum Teil stark unterscheiden, stehen in RapidClipse 3 verschiedene Daten-Container Typen zur Verfügung:
- Container (Tabelle) - Kann eine Liste mit Datensätzen (Items) speichern.
- Item (Datensatz) - Kann 1 Datensatz bestehend aus mehreren Properties speichern.
- Property (Einzelner Wert) - Kann nur 1 einzelnen Wert speichern.
Container
Ein Container kann eine Liste mit beliebig vielen Datensätzen (BeanItems) aufnehmen. RapidClipse bietet mit dem XdevLazyEntityContainer und dem XdevBeanItemContainer 2 verschiedene Container-Varianten.
XdevBeanItemContainer
Der XdevBeanItemContainer ist der Standard Daten-Container für benutzerdefinierte Queries.
- Bietet kein vollautomatisiertes Lazy-Loading zwischen Datenbank und Server, sondern lediglich zwischen Server und Client. Das gesamte Abfrageergebnis wird im XdevBeanItemContainer zwischengespeichert. Das Abfrageergebnis muss eigenständig mit Hilfe gängiger Abfragebedingungen minimiert werden.
- Manuelles Hinzufügen von Datensätzen (BeanItems) möglich.
- Wird von RapidClipse verwendet, wenn bei einer UI-Komponente in den Properties Entity > Data > findAll selektiert ist.
Summary:
Data-Container | Methoden | Erklärung | Example | UI-Komponenten |
---|---|---|---|---|
XdevBeanItemContainer | setContainerDataSource | XdevBeanItemContainer einer UI-Komponente zuweisen | table.setContainerDataSource(productContainer); |
|
getContainerDataSource | XdevBeanItemContainer von einer UI-Komponente zurückgeben lassen | XdevBeanItemContainer<Product> productContainer = table.getContainerDataSource(); |
Examples:
Abfrageergebnis in XdevBeanItemContainer speichern
Erzeugt ein neues DAO-Objekt selectProducts, um mit der Methode findAll die Datenbankabfrage SELECT * FROM PPRODUCTS ausführen zu können und speichert das Abfrageergebnis in der Liste productList.
ProductDAO selectProducts = new ProductDAO(); List<Product> productList = selectProducts.findAll();
Erzeugt einen neuen XdevBeanItemContainer productContainer vom Typ Product und weist diesen mit der Methode addAll die Liste productList zu, die das Abfrageergebnis enthält.
XdevBeanItemContainer<Product> productContainer = new XdevBeanItemContainer<Product>(Product.class); productContainer.addAll(productList);
Primary-Keys - Gibt eine Liste (Collection) aller Primary-Keys zurück.
Collection<?> itemIds = table.getContainerDataSource().getItemIds();
Wert via ID - Liefert den Wert mit der ID 5 zurück.
Product selProduct = table.getContainerDataSource().getItem(5).getBean();
XdevBeanItemContainer leeren
table.getContainerDataSource().removeAll();
XdevLazyEntityContainer
Der XdevLazyEntityContainer wird nur von RapidClipse verwendet, wenn bei einer UI-Komponente in den Properties Entity > Auto query data selektiert ist.
Bietet vollautomatisiertes Lazy-Loading zwischen Datenbank, Server und Client. Es werden immer nur so viele Datensätze zwischen Datenbank und Server übertragen, wie vom Client durch Scrollen oder Paging angefordert werden.
- Nimmt keine dynamischen SQLs entgegen (automatisch immer SELECT * FROM ...)
- Manuelles Hinzufügen von BeanItems nicht möglich.
Model für:
Item
Ein Item kann eine Liste mit Properties (einzelne Werten) und damit nur 1 Datensatz aufnehmen. RapidClipse verwendet standardmäßig die Item-Erweiterung BeanItem.
Chai | 10 boxes x 20 bags | 18 | 39 | 0 | false | 10 |
Summary:
Data-Container | Methoden | Erklärung | Example | UI-Komponenten |
---|---|---|---|---|
BeanItem | getItemDataSource | BeanItem von einer UI-Komponente zurückgeben lassen | BeanItem<Product> itemDataSource = fieldGroup.getItemDataSource(); |
|
setItemDataSource | BeanItem einer UI-Komponente zuweisen | fieldGroup.setItemDataSource(product); |
Model für:
Examples:
BeanItem instanzieren
BeanItem<Product> product = new BeanItem<Product>(null);
Selektierte Zeile aus XdevTable auslesen
BeanItem<Product> product = table.getSelectedItem();
Datensatz einem Formular zuweisen - Die Zuweisung erfolgt mit der Methode setItemDataSource.
fieldGroup.setItemDataSource(product);
Property
Eine Property kann nur einen einzelnen Wert (Datenfeld) aufnehmen.
Chai |
Summary:
Data-Container | Methoden | Erklärung | Example | UI-Komponenten |
---|---|---|---|---|
Property | getPropertyDataSource | Wert aus einer UI-Komponente auslesen. | Property<?> propertyDataSource = this.label.getPropertyDataSource(); |
|
setPropertyDataSource | Wert einer UI-Komponente zuweisen. | label.setPropertyDataSource("text"); |
Model für:
- XdevTextField
- XdevPasswordField
- XdevInlineDateField
- XdevPopupDateField
- XdevNativeSelect
- XdevRichTextArea
- XdevLabel
- XdevCheckBox
Exmaples:
Property instanzieren
Property<String> productName = new ObjectProperty<String>("Chai");
Datenfeld aus einer selektierten Zeile einer XdevTable auslesen
Property<String> productName = product.getItemProperty("productname");
- Wert einem XdevTextField zuweisen
Zuweisung mit der Methode setPropertyDataSource:
textField.setPropertyDataSource(productName);
Zuweisung mit der Methode setValue:
textField.setValue(productName);
Workflow von Daten-Eingang bis Visualisierung
XDEV Software Corp. - One Embarcadero Center, San Francisco, CA 94111, US
Copyright © 2015. XDEV Software Corp. All rights reserved.