Flutter SizedBox布局组件Widget使用示例详解

 更新时间:2023年02月13日 14:21:39   作者:IAM17  
这篇文章主要为大家介绍了Flutter SizedBox布局组件Widget使用示例详解

正文

Flutter Sizedbox 是一个 布局组件,用来给 child 添加 tight 约束的,也可以用来添加空白。

width,height是 Sizedbox 的参数

 BoxConstraints get _additionalConstraints {
    return BoxConstraints.tightFor(width: width, height: height);
 }
final BoxConstraints constraints = this.constraints;
if (child != null) {
  child!.layout(_additionalConstraints.enforce(constraints),
      parentUsesSize: true);
  size = child!.size;
} else {
  size = _additionalConstraints.enforce(constraints).constrain(Size.zero);
}

enforce 方法根据 _additionalConstraints 返回一个新约束,新约束保证在参数 constraints 的范围之内。

以上就是 SizedBox 的布局逻辑,通过代码我们分析一下 child constrains, SizedBox size。

child 的 constrains

constrains 是 tight ,SizedBox 透传 constrains 给 child。

constrains 是 loose,width 为空,SizedBox 透传 minWidth,maxWith 给 child;height为空,SizedBox 透传 minHeight,maxHeight 给 child。

constrains 是 loose,width 不为空, 在 constrains 范围内 给 child 的 width tight 约束;height 不为空 在 constrains 范围内 给 child 的 height tight 约束。

确定自己的大小

如果有 child ,和 child 一样大。

没有child ,constrains 是 tight ,大小为约束最小值。

没有child ,constrains 是 loose,在约束范围内由 width,height 参数指定。

SizedBox 的命名构造函数们

SizedBox 虽然本身很简单,但它命名构造函数确实不少。我们平时用的时候大多忽略了这些命名构造函数,所以应该先混个脸熟,用这些命名构造函数还是有好处的,可以增加代码的可读性。

SizedBox.expand

使 SizedBox 获得最大 Size,也就是和父 widget 一样大。

const SizedBox.expand({ super.key, super.child })
    : width = double.infinity,
      height = double.infinity;

SizedBox.shrink

让 SizedBox 尽量小。

const SizedBox.shrink({ super.key, super.child })
    : width = 0.0,
      height = 0.0;

SizedBox.fromSize

通过 size 来构造 SizedBox。

SizedBox.fromSize({ super.key, super.child, Size? size })
    : width = size?.width,
      height = size?.height;

SizedBox.square

保证 SizedBox 是一个正方形。

  const SizedBox.square({super.key, super.child, double? dimension})
    : width = dimension,
      height = dimension;

应用场景

为 child 提供 tight 约束。

当指定了 width,height 参数后,child 就获得了宽高的 tight 约束。保证 child 有固定大小。这对于固定布局非常有用。

为 children 之间提供空白。

可以用 padding 添加空白,但那样会增加一层嵌套,用 SizedBox 充当空白看起来更好一些。

占位

只是用来占位,比如 Spacer 中的 child 用的就是 SizedBox.shrink。

class Spacer extends StatelessWidget {
  const Spacer({super.key, this.flex = 1})
    : assert(flex != null),
      assert(flex > 0);
  final int flex;
  @override
  Widget build(BuildContext context) {
    return Expanded(
      flex: flex,
      child: const SizedBox.shrink(),
    );
  }
}

以上就是Flutter SizedBox布局组件Widget使用示例详解的详细内容,更多关于Flutter SizedBox布局组件Widget的资料请关注脚本之家其它相关文章!

相关文章

  • Dart多个future队列完成加入顺序关系及原子性论证

    Dart多个future队列完成加入顺序关系及原子性论证

    这篇文章主要介绍了Dart多个future队列完成加入顺序关系及原子性论证,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • Flutter学习笔记(二)创建一个flutter项目

    Flutter学习笔记(二)创建一个flutter项目

    这篇文章主要介绍了Flutter学习笔记(二)创建一个flutter项目,其中运行的过程,可能涉及到网络环境配置的问题,需要的朋友可以参考下
    2023-04-04
  • Dart语法之变量声明与数据类型实例详解

    Dart语法之变量声明与数据类型实例详解

    这篇文章主要为大家介绍了Dart语法之变量声明与数据类型实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • Flutter 图片开发核心技能快速掌握教程

    Flutter 图片开发核心技能快速掌握教程

    这篇文章主要为大家介绍了Flutter 图片开发核心技能快速掌握教程,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • 谷歌Sky语言怎么样?什么是Dart编程语言?

    谷歌Sky语言怎么样?什么是Dart编程语言?

    据外媒报道,在日前举行Dart开发者峰会上,谷歌对外正式展示了Android最新的开发语言Sky,据悉,Sky本质上就是谷歌自主的网页开发语言Dart.
    2015-05-05
  • Dart String字符串的常用方法总结概述

    Dart String字符串的常用方法总结概述

    这篇文章主要为大家介绍了Dart String字符串的常用方法概述,总结整理了大概4000多字,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • Flutter入门学习Dart语言变量及基本使用概念

    Flutter入门学习Dart语言变量及基本使用概念

    这篇文章主要为大家介绍了Flutter入门学习Dart语言变量及基本使用概念,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • Flutter Dart快速排序算法示例详解

    Flutter Dart快速排序算法示例详解

    这篇文章主要为大家介绍了Flutter Dart快速排序算法示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • Dart 异步编程生成器及自定义类型用法详解

    Dart 异步编程生成器及自定义类型用法详解

    这篇文章主要为大家介绍了Dart 异步编程生成器及自定义类型用法示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • 浅析Dart语言的异步处理

    浅析Dart语言的异步处理

    Dart是一个单线程语言,我们在处理耗时操作的时候使用stream或者future来实现,在这篇文章中我们将简单的给大家聊一聊Dart语言的异步处理
    2023-06-06

最新评论