flutter之Row

举报
青年码农 发表于 2022/08/24 22:27:32 2022/08/24
【摘要】 1 Row Row是一个用于水平展示多个子控件的控件。row这个控件不会滚动。如果你有一行控件在空间不足的情况下可以滚动,考虑使用ListView类。  2 构造函数 Row({ Key key, MainAxisAlignment mainAxisAlignment, ...

1 Row

Row是一个用于水平展示多个子控件的控件。row这个控件不会滚动。如果你有一行控件在空间不足的情况下可以滚动,考虑使用ListView类。 

2 构造函数


   
  1. Row({
  2. Key key,
  3. MainAxisAlignment mainAxisAlignment,
  4. MainAxisSize mainAxisSize,
  5. CrossAxisAlignment crossAxisAlignment,
  6. TextDirection textDirection,
  7. VerticalDirection verticalDirection,
  8. TextBaseline textBaseline,
  9. List<Widget> children = const <Widget>[],
  10. })

3 常用属性

3.1 crossAxisAlignment:子组件沿着 Cross 轴(在 Row 中是纵轴)如何摆放,其实就是子组件对齐方式

3.1.1 子组件在 Row 中顶部对齐

CrossAxisAlignment:CrossAxisAlignment.start;
  

3.1.2 子组件在 Row 中底部对齐

CrossAxisAlignment:CrossAxisAlignment.end;
  

3.1.3 子组件在 Row 中居中对齐

CrossAxisAlignment: CrossAxisAlignment.center;
  

3.1.4 拉伸填充满父布局

CrossAxisAlignment:CrossAxisAlignment.stretch;
  

3.1.5 在 Row 组件中会报错

CrossAxisAlignment:CrossAxisAlignment.baseline;
  

3.2 mainAxisAlignment:子组件沿着 Main 轴(在 Row 中是横轴)如何摆放,其实就是子组件排列方式

3.2.1 靠左排列

mainAxisAlignment:MainAxisAlignment.start;
  

3.2.2 靠右排列

mainAxisAlignment:MainAxisAlignment.end;
  

3.2.3 居中排列

mainAxisAlignment:MainAxisAlignment.center;
  

3.2.4 每个子组件左右间隔相等,也就是 margin 相等

mainAxisAlignment:MainAxisAlignment.spaceAround;
  

3.2.5 两端对齐,也就是第一个子组件靠左,最后一个子组件靠右,剩余组件在中间平均分散排列

mainAxisAlignment:MainAxisAlignment.spaceBetween;
  

3.2.6 每个子组件平均分散排列,也就是宽度相等

mainAxisAlignment:MainAxisAlignment.spaceEvenly;
  

3.3 mainAxisSize:Main 轴大小

3.3.1 相当于 Android 的 match_parent

mainAxisSize:MainAxisSize.max;
  

3.3.2 相当于 Android 的 wrap_content

mainAxisSize:MainAxisSize.min;
  

3.4 textDirection:子组件排列顺序

3.4.1 从左往右开始排列

textDirection: TextDirection.ltr;
  

3.4.2 从右往左开始排列

textDirection: TextDirection.rtl;
  

3.5 verticalDirection:确定如何在垂直方向摆放子组件,以及如何解释 start 和 end,指定 height 可以看到效果

3.5.1 Row 从下至上开始摆放子组件,此时我们看到的底部其实是顶部

verticalDirection: VerticalDirection.up;
  

3.5.2 Row 从上至下开始摆放子组件,此时我们看到的顶部就是顶部

verticalDirection: VerticalDirection.down;
  

3.6 children Row的子widget

children: <Widget>[],
  

文章来源: blog.csdn.net,作者:NMGWAP,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/NMGWAP/article/details/125067137

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。