Flutter学习之七 Expanded

登高而招,臂非加长也,而见者远;

👈🏻 Flutter学习之六 Row和Column

前言

上面文章介绍了RowColumn的简单布局,但是在使用的时候,一些细节的布局还得使用其他组件,其中就有专门针对弹性布局而生的Expanded

正文

RowColumn中,我提到了弹性布局FlexRowColumn都是继承自FlexFlex比较简单,定义如下:

Flex({
  Key? key,
  required this.direction,
  this.mainAxisAlignment = MainAxisAlignment.start,
  this.mainAxisSize = MainAxisSize.max,
  this.crossAxisAlignment = CrossAxisAlignment.center,
  this.textDirection,
  this.verticalDirection = VerticalDirection.down,
  this.textBaseline, // NO DEFAULT: we don't know what the text's baseline should be
  this.clipBehavior = Clip.none,
  List<Widget> children = const <Widget>[],
})

看到这个是不是觉得眼熟,在这里就不再详细说了。Flex、Row、Column是弹性布局组件,Expanded只能用于弹性局部中,记住这点就行了。

Expanded作用

很简单就一句话,Expanded包含的组件可以占据剩余的空间。

  • 场景一

先看下面一个常见的页面,图1:

1.png

简单分析一下,首先是横向布局,左右边距都是20,左边是个头像,右边是个按钮,中间是Text占据所有空间,这时候用Expanded是最香的。代码如图2:
2.png

细心的小伙伴已经发现了,在头像和文字中间我用了一个SizeBox,因为他俩中间是有个10的间距的。这时候用SizeBox是很舒服的。可以开启图层看下,如图3:
3.png

  • 场景二

有些需求是组件之间要有一定的比例,先上效果图,如图4:

4.png

上面的红蓝红比例是1:2:1来占据Row的空间,不管手机屏幕怎么变化,这个比例是不会变的,代码如图5:
5.png

后记

  • Expanded是用弹性布局(Flex、Row、Column)里面的,为了占用剩余所有空间。
  • 在弹性布局中,如果2个组件之间有小间距,可以使用SizeBox来处理。
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一. 单子布局组件 单子布局组件的含义是其只有一个子组件,可以通过设置一些属性设置该子组件所在的位置信息等。比较常...
    AlanGe阅读 599评论 0 0
  • 为了实现界面内组件的各种排布方式,我们需要进行布局,和其他端不同的是,Flutter中因为万物皆Widget,所以...
    5e4c664cb3ba阅读 668评论 1 1
  • 邂逅FLutter 万物皆是Widget 一般缩进2个空格 文字居中 Widget Center() Materi...
    JackLeeVip阅读 3,302评论 0 4
  • 故不登高山,不知天之高也;不临深溪,不知地之厚也; 👈🏻 Flutter学习之五 文件命名规范及代码格式化[htt...
    MQ_Twist阅读 1,021评论 0 1
  • 一. 单子布局组件 单子布局组件的含义是其只有一个子组件,可以通过设置一些属性设置该子组件所在的位置信息等。比较常...
    张无奈阅读 401评论 0 0