flutter2:Container的简介与尺寸

1.Container简介

Container是一种Widget,同时Container就是用来包裹其他Widget然后给他们设置效果的,例如padding,margin,border,background这些东西(当然用的时候不是我这里直接说的这些属性名)

2.Container的尺寸

1.影响因素

目前我学到的是三项:约束、尺寸、子Widget

他们的作用效果也是:约束>尺寸>子Widget

总体影响效果:(下面涉及到了约束是什么这件事,在后文会有提及)

复制代码
默认情况下:只要没约束没尺寸就是尽可能小
有了子View: 尽可能小然后按照尺寸和约束调节
在约束眼中,子Widget和尺寸是一样的,如果有他们,就先按他们来,然后再给他们进行约束限制,如果没有他们,对于没有约束最大的属性就会matchParent

2.先说Constraint这个东西吧

他是个约束,简单来说就是表示minWidth,minHeight,maxWidth,maxHeight的一个类,对于Container这个小部件而言,约束在设置的时候是设置的它自身这个小部件的最大最小宽高。

1.约束方法

1.直接设置最大最小宽高

BoxConstraints(minHeight: 120,maxHeight: 120,minWidth: 120,maxWidth: 120)

2.用现有的BoxConstraints的方法简单设置

  1. BoxConstraints.loose(Size size)
  2. BoxConstraints.expand({double? width, double? height})
  3. BoxConstraints.fromViewConstraints(ui.ViewConstraints constraints)
  4. BoxConstraints.tight(Size size)
  5. BoxConstraints.tightFor({double? width, double? height})
  6. BoxConstraints.tightForFinite({ double width = double.infinity, double height = double.infinity, })

2.现成的这几个方法的作用

  1. loose:仅约束最大尺寸

  2. expand:未指定的维度必须填满父容器空间

  3. fromViewConstraints:将平台原生视图约束转换为BoxConstraints

  4. tight:严格固定为精确尺寸

  5. tightFor:可选择性固定某些维度,未指定的维度自由

  6. tightForFinite:只对有限数值严格固定,∞值视为未指定

3.demo代码

Dart 复制代码
// 无子无约束无尺寸不显示
class LearnContainers extends StatelessWidget {
  const LearnContainers({super.key});

  @override
  Widget build(BuildContext context) => Container(color: Colors.blue);
}
// 有子无约束无尺寸,wrapContent
class LearnChildContainers extends StatelessWidget {
  const LearnChildContainers({super.key});

  @override
  Widget build(BuildContext context) =>
      Container(color: Colors.blue, child: Text("有子Widget的Container"));
}
// 无子有约束,先mathParent,然后根据约束再更改尺寸
class LearnWithConstraintContainers extends StatelessWidget {
  const LearnWithConstraintContainers({super.key});

  @override
  Widget build(BuildContext context) => Container(
    color: Colors.blue,
    constraints: BoxConstraints(
      minWidth: 100,
      minHeight: 100,
      maxWidth: 100,
      maxHeight: 100,
    ),
  );
}
// 有子有约束,先wrapContent,然后根据约束再更改尺寸
class LearnChildWithConstraintContainers extends StatelessWidget {
  const LearnChildWithConstraintContainers({super.key});

  @override
  Widget build(BuildContext context) => Container(
    color: Colors.blue,
    constraints: BoxConstraints(minWidth: 100, minHeight: 100),
    child: Text("有子Widget有约束的Container"),
  );
}
// 有子有尺寸,按尺寸来
class LearnChildWithSizedContainers extends StatelessWidget {
  const LearnChildWithSizedContainers({super.key});

  @override
  Widget build(BuildContext context) => Container(
    color: Colors.blue,
    width: 100,
    height: 100,
    child: Text("有子Widget有尺寸的Container"),
  );
}
// 有子有尺寸有约束,先按尺寸来,然后根据约束更改尺寸
class LearnChildWithSizedAndConstraintContainers extends StatelessWidget {
  const LearnChildWithSizedAndConstraintContainers({super.key});
  @override
  Widget build(BuildContext context) => Container(
    color: Colors.blue,
    width: 100,
    height: 100,
    constraints: BoxConstraints(minWidth: 120, minHeight: 120),
    child: Text("有子有尺寸有约束的Container"),
  );
}
// 无子有尺寸有约束,先按尺寸来,然后根据约束更改尺寸
class LearnWithSizedAndConstraintNotContainers extends StatelessWidget {
  const LearnWithSizedAndConstraintNotContainers({super.key});
  @override
  Widget build(BuildContext context) => Container(
    color: Colors.blue,
    width: 100,
    height: 100,
    constraints: BoxConstraints(minWidth: 120, minHeight: 120),
  );
}
相关推荐
爱敲代码的小鱼3 分钟前
Vue的简介:
前端·javascript·vue.js
GHL2842710904 分钟前
TeamTalk-msg_server学习
运维·服务器·c++·学习
符哥20088 分钟前
Fastjson2.X 使用详解
android·java
好好学习天天向上~~16 分钟前
3_Linux学习总结_基础指令
linux·服务器·学习
H_ZMY18 分钟前
前端瀑布流布局:从基础实现到高性能优化全解析
前端·性能优化
星夜落月22 分钟前
从零部署Wallos:打造专属预算管理平台
服务器·前端·网络·建站
郝学胜-神的一滴23 分钟前
Linux网络编程之Socket函数:构建通信的桥梁
linux·服务器·网络·c++·程序人生
tb_first24 分钟前
万字超详细苍穹外卖学习笔记3
java·jvm·笔记·学习·spring·tomcat·maven
qq_124987075326 分钟前
基于html的书城阅读器系统的设计与实现(源码+论文+部署+安装)
前端·vue.js·spring boot·后端·mysql·信息可视化·html