Flutter弹性布局Flex使用及其相关属性详解

目录

Flex相关属性及其定义

direction

mainAxisAlignment 

crossAxisAlignment    

verticalDirection

textDirection


简介

弹性布局允许子widget按照一定比例来分配父容器空间,弹性布局的概念在其UI系统中也都存在,如H5中的弹性盒子布局,Android中的FlexboxLayout。Flutter中的弹性布局主要通过Flex和Expanded来配合实现,Flex是Row和Column的父类

RowColumn都只会在主轴方向占用尽可能大的空间,而纵轴的长度则取决于他们最大子元素的长度

Flex相关属性及其定义

 Flex({
    Key key,
    //排版方向 必须的  分为 Horizontal 和 vertical
    @required this.direction,

    //主轴排版对齐方式 可选值有 start end center spaceBetween spaceAround spaceEvenly
    this.mainAxisAlignment = MainAxisAlignment.start,

    //主轴尺寸 基本用不到 max 即可
    this.mainAxisSize = MainAxisSize.max,

    //交叉轴排版对齐方式 start end center stretch baseline
    this.crossAxisAlignment = CrossAxisAlignment.center,

    //水平方向顺序  rtl  ltr
    this.textDirection,

    //垂直方向顺序 up down
    this.verticalDirection = VerticalDi
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flutter中的Flex布局是一种弹性布局模型,它可以让子元素按照一定的比例分配父容器的可用空间。Flex布局主要包含三个组件:FlexFlexible和Expanded。 1. Flex Flex是一个容器组件,它可以将子组件按照一定的比例排列。Flex有两个属性:direction和mainAxisAlignment,其中direction表示子组件排列的方向,默认为水平方向,mainAxisAlignment表示子组件在主轴上的对齐方式。 2. Flexible Flexible是一个伸缩组件,它可以根据父容器的可用空间来调整自身的尺寸。Flexible有三个属性flex、fit和child,其中flex表示子组件的比例,fit表示子组件在可用空间不足时的适应方式,child表示子组件。 3. Expanded Expanded是Flexible的一种特殊情况,它的flex属性默认为1。使用Expanded可以让子组件占据父容器剩余的所有空间。 下面是一个简单的Flex布局示例: ``` Flex( direction: Axis.horizontal, mainAxisAlignment: MainAxisAlignment.center, children: <Widget>[ Flexible( flex: 1, fit: FlexFit.tight, child: Container( height: 50, color: Colors.red, ), ), Flexible( flex: 2, fit: FlexFit.loose, child: Container( height: 50, color: Colors.blue, ), ), Expanded( child: Container( height: 50, color: Colors.green, ), ), ], ) ``` 在这个示例中,我们创建了一个水平方向的Flex容器,其中有三个子组件。第一个子组件使用Flexible,它的flex属性为1,表示占据1/3的空间;第二个子组件也使用Flexible,它的flex属性为2,表示占据2/3的空间;第三个子组件使用了Expanded,它会占据剩余的所有空间。在这个示例中,第一个子组件使用了tight适应方式,它会尽可能地占据可用空间;第二个子组件使用了loose适应方式,它会根据自身的尺寸来调整大小。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值