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

Flutter弹性布局Flex详解与属性应用
本文介绍了Flutter中的弹性布局Flex,详细讲解了Flex的相关属性,包括direction、mainAxisAlignment、crossAxisAlignment、verticalDirection和textDirection。通过这些属性,开发者可以灵活地控制子组件在父容器中的排列方式和空间分配,实现复杂且动态的界面布局。

目录

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 = VerticalDirection.down,

    this.textBaseline,
    this.clipBehavior = Clip.hardEdge,

direction

排版方向 必须的 分为 Horizontal 和 vertical 两种顾名思义 横向与纵向

mainAxisAlignment 

主轴排版方式

其可选值有 start end center spaceBetween(两个顶端没有边距 中间间隔均匀分布) spaceAround(两边边距相等,中间间隔均分) spaceEvenly(两边边距与中间间隔均分)

具体效果如下 

crossAxisAlignment    

交叉轴排版对齐方式有 start end center stretch(拉伸) baseline(基线)等可选值

verticalDirection

垂直方向顺序 up down 效果如下
 

textDirection

 //水平方向顺序  rtl  ltr
rtl 从右往左 理解为  r to  l

ltr 从左往右 理解为  l to  r

欢迎关注我的公众号 这将是对我最大的鼓励与支持:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值