formLayout
formLayout
is a responsive layout that arranges components into columns. The number of columns changes depending on the layout width.
-
XML element:
formLayout
-
Java class:
FormLayout
Basics
By default, formLayout
arranges all components into two columns.
<formLayout id="formLayout">
<textField placeholder="City" label="Where from?"/>
<textField placeholder="City" label="Where to?"/>
<datePicker label="Depart"/>
<datePicker label="Return"/>
<button text="Search tickets"/>
</formLayout>
data:image/s3,"s3://crabby-images/4f54f/4f54f355fc9edd5516f484c93c38c4d351c4a843" alt="form layout basic 1"
When the layout width is smaller, it automatically adjusts to a single column.
data:image/s3,"s3://crabby-images/5ee06/5ee0617e45611d530c7781b2f15acb611a448255" alt="form layout basic 2"
Columns
Define how many columns are shown based on the layout width.
@ViewComponent
private FormLayout formLayout;
@Subscribe
public void onInit(final InitEvent event) {
formLayout.setResponsiveSteps(
new FormLayout.ResponsiveStep("0", 1),
new FormLayout.ResponsiveStep("320px", 2),
new FormLayout.ResponsiveStep("460px", 3),
new FormLayout.ResponsiveStep("600px", 4),
new FormLayout.ResponsiveStep("740px", 5));
}
data:image/s3,"s3://crabby-images/cba8b/cba8b8a6a58f22367ef588d0653cd4addf6acb52" alt="form layout columns"
Column Span
formLayout
respects the nested components' properties. Use the colspan property to set the number of columns occupied by the component.
<formLayout>
<textField placeholder="City" label="Where from?"/>
<textField placeholder="City" label="Where to?"/>
<datePicker label="Depart"/>
<datePicker label="Return"/>
<button text="Search tickets" colspan="2"/>
</formLayout>
data:image/s3,"s3://crabby-images/a80fa/a80fa440a039e27c94b54f38f2ef0f6fe4fe8bed" alt="form layout"
Attributes
id - classNames - colspan - dataContainer - enabled - height - labelsPosition - maxHeight - maxWidth - minHeight - minWidth - visible - width -
Handlers
Чтобы сгенерировать заглушку обработчика в Jmix Studio, используйте вкладку Handlers панели инспектора Jmix UI, или команду Generate Handler, доступную на верхней панели контроллера экрана и через меню Code → Generate (Alt+Insert / Cmd+N). |
See Also
See Vaadin Docs for more information.