Flutter中的单孩子和多孩子布局组件

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


一、单孩子布局组件

直接或间接地继承自SingleChildRenderObjectWidget类,既能提供丰富的装饰能力,也能提供部分特定的布局能力。

1. Container组件

Container组件继承自StatelessWidget类,它由基本的绘制、位置和大小组件组成。Container组件的常用属性和功能说明如表所示。
在这里插入图片描述
示例代码:
在这里插入图片描述
实现效果:
在这里插入图片描述

2. Padding组件

Padding组件直接继承自SingleChildRenderObjectWidget类,它是用于设置内边距的组件.该组件的常用属性和功能说明如表所示。
在这里插入图片描述

3. Align组件

Align组件直接继承自SingleChildRenderObjectWidget类,它是用于设置子元素的对齐方式.孩组件的常用属性和功能说明如表所示。
在这里插入图片描述

class Align extends SingleChildRenderObjectWidget {
  /// Creates an alignment widget.
  ///
  /// The alignment defaults to [Alignment.center].
  const Align({
    super.key,
    this.alignment = Alignment.center,
    this.widthFactor,
    this.heightFactor,
    super.child,
  }

4. Center组件

Center组件直接继承自Align类,它是用于设置子元素的居中方式.该组件的常用属性和功能说明如表所示。
在这里插入图片描述

class Center extends Align {
  /// Creates a widget that centers its child.
  const Center({ super.key, super.widthFactor, super.heightFactor, super.child });
}

二、多孩子布局组件

大多数直接或间接地继承自MultiChildRenderObjectWidget类,这些组件能够提供特定的布局能力,如将多个组件按水平(行)方向排列、按垂直(列)方向排列等.

1. Row组件

Row组件直接继承自Flex类,间接继承自MultiChildRenderObjectWidget类,它是一个可以沿水平方向展示子元素的布局组件。Row组件的常用属性和功能说明如表所示。
在这里插入图片描述

在这里插入图片描述

2.Column组件

Column组件直接继承自Flex类,间接继承自MultiChildRenderObjectWidget类,它是一个可以沿垂直方向展示子元素的布局组件。Column组件的常用属性和功能说明如表所示。
在这里插入图片描述

3. Flex组件

Flex组件直接继承自MultiChildRenderObjectWidget类,它是一个可以沿主轴方向展示子元素的布局组件,Flex组件的常用属性和功能说明如表所示.。
在这里插入图片描述

当direction的值为Axis.horizontal时,同Row组件的功能;当direction的值为Axis.vertical时,同Column组件的功能。

4. Expanded组件

Expanded组件直接继承自Flexible类,它用于展开Row、Column或Flex组件承载的子元素,也就是将子元素的宽度或高度扩展至充满主轴方向的空白空间。Expanded组件虽然不是多孩子布局组件,但是它经常与多孩子布局组件组合使用。Expanded组件的常用属性和功能说明如表所示。
在这里插入图片描述

const Expanded({
    super.key,
    super.flex,//控制孩子组件所占份数
    required super.child,
  })

在这里插入图片描述
在这里插入图片描述

5. Wrap组件

Wrap组件直接继承自MultiChildRenderObjectWidget类,它是一个可以将其承载的子元素自动换行的组件.在Row、Column或Flex组件承载的子元素时,如果子元素超过屏幕范围,则会报溢出错误.Wrap组件的direction、crossAxisAlignment、 textDirection、verticalDirection、children属性与Row(包括Column和Flex)组件的意义、用法相同,其他常用属性和功能说明如表所示。
在这里插入图片描述

6. Stack组件

Stack组件直接继承自MultiChildRenderObjectWidget类,它是一个可以将其承载的子元素堆叠布局的组件,它的常用属性和功能说明如表所示。
在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值