FlexRow
FlexRow is designed to lay out child widgets horizontally and proportionally from the available space given by its parent. By default, flexRow assigns equal space to each child (flex=1
), but this can be customized to accommodate various design requirements.
Best Practices
- Use FlexRow when you need a horizontal layout with proportional space distribution among the children.
- Avoid using FlexRow in a scrollable parent, such as scrollable Row, without a fixed width, as it will lead to layout issues. FlexRow and its children need to be constrained to a definite size to properly calculate the flex distribution.
- Avoid using FlexRow in another Row. Row does not constrain its children's dimensions, which FlexRow requires to calculate the flex distribution. Instead consider giving the FlexRow a width or use all FlexRow(s) up the parent chain.
Key Concepts
- flex: Determines the space a child widget occupies relative to its siblings. By default, all children in a FlexRow have a flex value of 1 unless specified.
- flexMode: Dictates how a child widget uses its allocated space. It can be set to the below:.
expanded
: The child will attempt to fill its allocated space based on the flex factor (this is the default).flexible
: The child occupies only the space it needs, up to its flex factor.none
: The child occupies the space it needs (flex factor is ignored).
- When laying out its children, FlexRow follows this specific order:
-
- Widgets with flexMode marked as
none
will be laid out first and receive all the space they need. Use caution as this can overflow the parent's available spaces (use 'flexible' is probably sufficient most of the time).
- Widgets with flexMode marked as
-
- Widgets marked as
flexible
are laid out next. They're allowed to occupy space up to their flex factor but can be smaller if they don't require all the space. This is useful for widgets that can size themselves according to their content but should be limited to a specific portion of the available space.
- Widgets marked as
-
- The remaining space is then divided among
expanded
widgets according to their flex factors. These widgets are stretched to fill the allocated space, ensuring that all available space is used.
- The remaining space is then divided among
-
Caveats
- Row height: Note that setting a height for a FlexRow acts more like a maximum height constraint. The FlexRow determines its actual height based on the tallest child, aligning the other children along the vertical cross-axis according to this height. This means if this actual height is less than the specified height, the
crossAxis
only affects the alignment of the children within the determined (lesser) height. If you wish to stretch all the children to the same specified height, addcrossAxis: stretch
in addition to the fixed height.
Usage
A simple FlexRow with three child widgets, each taking up equal space (all have flex=1 by default):
FlexRow:
children:
- Text:
text: Child 1
- Text:
text: Child 2
- Text:
text: Child 3
Assigning different flex values to children to control their space distribution. In the example below, "Child 2" will occupy twice the space of "Child 1" and "Child 3":
FlexRow:
children:
- Text:
text: Child 1 # default flex=1 since not specified
- Text:
text: Child 2
styles:
flex: 2
- Text:
text: Child 3
styles:
flex: 1
Adjusting FlexMode to control how children occupy their allocated space. In the example below, "Flexible Child" will be laid out with the size it needs, up to a 1/3 of the available space. "Expanded Child" will be laid out next, occupy the rest of the available space, but not smaller than 2/3 of the available space (since Flexible can only grow to 1/3 max, and all available spaces will be used):
FlexRow:
children:
- Text:
text: Flexible Child
styles:
flexMode: flexible
- Text:
text: Expanded Child
styles:
flex: 2
flexMode: expanded
Related
- See FlexColumn for a similar layout in the vertical direction.
- See Row for a more generic and scrollable container for laying out children horizontally.
Reference
Properties
Property | Type | Description |
---|---|---|
children | Widget[] | An array of child widgets to be laid out in the column. |
onTap | Action | An action that is triggered when the widget is tapped. |
onTapHaptic | TapHaptic | The type of haptic feedback to be triggered on tap. |
styles | object | See properties |
Styles
Style Property | Type | Description |
---|---|---|
mainAxis | string | Alignment of children along the main axis (vertical). Options: start , end , center , spaceBetween , spaceAround , spaceEvenly . |
crossAxis | string | Alignment of children along the cross axis (horizontal). Options: start , end , center , stretch , baseline . |
mainAxisSize | MainAxisSize | How to size the container along the main axis. |
gap` | integer | The gap between child widgets, in logical pixels. |
fontFamily | string | The font family to use for text within the widget. |
fontSize | integer | The size of the font to use for text within the widget. |
width | integer | The width of the widget, in logical pixels. |
height | integer | The height of the widget, in logical pixels. |
clipContent | boolean | Whether to clip the widget's content. Useful for preventing overflow. |
boxShadow | BoxShadow | Shadow properties for the widget. |
borderRadius | BorderRadius | The radius of the widget's corners. |
borderColor | Color | The color of the widget's border. |
borderWidth | integer | The width of the widget's border, in logical pixels. |
backgroundColor | Color | The widget's background color. |
backgroundImage | BackgroundImage | Overlay an image on the background of this widget |
backgroundGradient | Gradient | Background gradient of the box |
padding | Padding | Padding inside the widget, affecting its child widgets. |
margin | Margin | Margin outside the widget, affecting its position relative to others. |
flex | integer | Applicable only inside FlexRow or flexRow. Determines the space allocated to this widget relative to its siblings. |
flexMode | FlexMode | Determines how the widget should occupy the space allocated to it by the flex property. |
visible | boolean | Toggles the widget's visibility. An invisible widget will not occupy UI space unless visibilityTransitionDuration is specified. |
visibilityTransitionDuration | number | The duration in seconds for a widget to animate between visible and invisible states. |
opacity | double | Adjusts the opacity of the widget. Values range from 0 (fully transparent) to 1 (opaque). Default is 1 . |
elevation | integer | The z-coordinate at which to place this widget relative to its parent. This affects the size of the shadow displayed. |
elevationShadowColor | Color | The shadow color for the elevation. |
elevationBorderRadius | BorderRadius | Should match the widget's borderRadius if set, to ensure the shadow properly matches the widget's border radius. |
alignment | Alignment | Aligns this widget relative to its parent. |
enableSplashFeedback | boolean | Toggles splash effect feedback for the widget when true . |
splashColor | string | Defines the color of the splash effect when enableSplashFeedback is true. |
splashDuration | integer | This is the duration it takes to fill the widget surface with the splashColor.The duration in ms when tap and release on the widget. |
splashFadeDuration | integer | The duration it takes to fade out once tapped. Since a typical tap starts and ends immdiately, this splashFadeDuration executes almost at the same time as the splashDuration, so ideally it should be equal or longer than splashDuration to see the entire effect. |
unconfirmedSplashDuration | integer | This happens when the user tap and hold (not yet released). It is called unconfirmed since the tap will be cancelled if the user moves out of the tap area and release. Usually this should be longer (around 1 secs) to signify that the user has not confirmed the tap. |
stackPositionTop | integer | The distance of the child's top edge from the top of the parent Stack. Only applicable for Stack's children. |
stackPositionBottom | integer | The distance of the child's bottom edge from the bottom of the parent Stack. Only applicable for Stack's children. |
stackPositionLeft | integer | The distance of the child's left edge from the left of the parent Stack. Only applicable for Stack's children. |
stackPositionRight | integer | The distance of the child's right edge from the right of the parent Stack. Only applicable for Stack's children. |
captureWebPointer | boolean | Applicable for Web only. Ensures mouse clicks are captured by the widget, useful for overlaying widgets on certain HTML containers. |