Flutter Expanded VS Flexible
在Flutter中,当需要填充容器(Row
, Column
, or Flex
)剩余空间的时候,可以使用Expanded
或Flexible
,本文对这二者的差异做一分析。
分析
Expanded
比较容易理解,他会强制child改变大小,占据容器的剩余空间,如果有多个Expanded
的话,会按照他们的flex占比来分配每个child可以占据的空间大小。
Flexible
稍微特殊一些,有时候看起来似乎他的child占据的大小既不全是父布局的剩余空间,也不全是刚刚包裹child内容的大小。
让我们看一下Flexible
的源码:
1 | const Flexible({ |
可以看到,默认情况下他使用的fit
模式是FlexFit.loose
,查阅文档定义可知:
1 | FlexFit.loose:The child can be at most as large as the available space (but is allowed to be smaller). |
也就是说,默认情况下,Flexible
的child最大可以是父容器分配给Flexible
的大小(假设为MaxSzie
)。
但是,如果child的大小比这个MaxSzie
要小的话,那么允许child按照自己的大小来显示。
而如果Flexible
的fit
是FlexFit.tight
的话,就会强制child大小为MaxSzie
,效果和Expanded
一致,实际上Expanded
就是FlexFit.tight
模式的Flexible
:
1 | class Expanded extends Flexible { |
对于上述的结论,我们可以从下面的代码中得到证实:
1 | main() => runApp(MaterialApp(home: BodyWidget())); |
总结
Expanded
和Flexible
默认情况下都会按照flex
占据父容器剩余的可用空间,但是不同的是,Expanded
会强制child改变大小为父容器分配的大小,而Flexible
则会告诉child,最大只能是父容器分配的大小,要是child想要小一些的话,也可以按照child的大小显示。
如果改变Flexible
的fit
为FlexFit.tight
的话,Expanded
和Flexible
没有差别。