BoxLayout
BoxLayout
is a container with the sequential placement of components.
Component’s XML-names: hbox
,vbox
and flowBox
.
Basics
There are three types of BoxLayout
:
hbox
hbox
− components are placed horizontally:
<layout>
<hbox id="hbox"
spacing="true">
<label align="MIDDLE_LEFT"
value="Label"/>
<textField inputPrompt="TextField" required="true"/>
<button caption="Button"/>
<button caption="Button"/>
</hbox>
</layout>
data:image/s3,"s3://crabby-images/478fb/478fbc3dcf448cff5414520a7ab885faa0de3def" alt="hbox"
vbox
vbox
− components are placed vertically, width=100%
by default.
<layout>
<vbox id="vbox"
spacing="true">
<label value="Label"/>
<textField inputPrompt="TextField" required="true"/>
<button caption="Button"/>
<button caption="Button"/>
</vbox>
</layout>
data:image/s3,"s3://crabby-images/a240c/a240c122e96f15b11f1a15eda4fad3c500cf0c84" alt="vbox"
flowbox
flowBox
− components are placed horizontally with line-wrapping. If there is not enough space in a line, the components that do not fit will be displayed in the next line.
<layout>
<flowBox id="flowBox"
spacing="true"
width="300px">
<label value="Label"/>
<textField inputPrompt="TextField"/>
<button caption="Button"/>
<button caption="Button"/>
</flowBox>
</layout>
data:image/s3,"s3://crabby-images/74e5e/74e5e4f46fbb0a1fd3120db113c4acf9f5c62585" alt="flow box"
Styling
You can use BoxLayout
to create enhanced composite layouts. For example, the stylename
attribute with card
or well
value along with stylename="v-panel-caption"
for an enclosed container will make a component look like Vaadin Panel:
<layout>
<vbox stylename="well"
height="200px"
width="300px"
expand="message"
spacing="true">
<hbox stylename="v-panel-caption"
width="100%">
<label value="Widget caption"/>
<button align="MIDDLE_RIGHT"
icon="font-icon:EXPAND"
stylename="borderless-colored"/>
</hbox>
<textArea id="message"
inputPrompt="Enter your message here..."
width="280"
align="MIDDLE_CENTER"/>
<button caption="Send message"
width="100%"/>
</vbox>
</layout>
data:image/s3,"s3://crabby-images/742ba/742ba3d400e876b4787fe557668dbfcc1c1d0730" alt="vaadin panel"
All XML Attributes
align - box.expandRatio - caption - captionAsHtml - colspan - contextHelpText - contextHelpTextHtmlEnabled - css - description - descriptionAsHtml - editable - expand - height - htmlSanitizerEnabled - icon - id - margin - requiredIndicatorVisible - responsive - rowspan - spacing - stylename - visible - width