Flutter 容器盒子模型的使用示例

作者:岛上码农 时间:2023-06-18 18:47:43 

样例代码

在讲 Flutter 的盒子模型前,先看看HTML 中的盒子模型。如下图所示,一个页面元素包括了与父级容器的外边距(margin),自身内容与边框的内边距(padding)。外边距 和内边距都可以通过 LTRB (左、上、右、下)单独设定四个方向的大小。

Flutter 容器盒子模型的使用示例

Flutter 的盒子模型和 HTML 的是一样的,而通用的容器 Container 就相当于是一个通用的容器,和 HTML 的 div 标签一样。如果要控制一个元素的尺寸,外边距,内边距和边框,最通用的做法是使用 Container 容器将元素包裹。当然 Flutter 也提供了一些更为具体的布局组件方便开发,例如 :

  • SizedBox:指定尺寸的容器。

  • ConstaintedBox:带约束条件的容器,如限制最小最大宽度和高度。

  • DecoratedBox:带装饰的容器,比如渐变色。

  • RotatedBox:旋转一定角度的容器。

上面这些组件实际都可以通过 Container 的参数设置完成,只是开发的时候使用具体的容器可以减少组件参数。

样例代码

下面就使用一个具体的例子来说明盒子模型的具体概念,由于这里不涉及数据变化引起界面变化,因此直接使用 Stateless 无状态组件,代码如下:


class MyApp extends StatelessWidget {
 @override
 Widget build(BuildContext context) {
   return MaterialApp(
     title: 'Flutter 盒子模型',
     theme: ThemeData(
       primarySwatch: Colors.blue,
     ),
     home: Scaffold(
       appBar: AppBar(
         title: Text('盒子模型'),
       ),
       body: Center(
         child: Container(
           width: 300,
           height: 300,
           color: Colors.blue,
           child: Container(
             color: Colors.red,
             margin: EdgeInsets.fromLTRB(10, 0, 20, 30),
             child: Container(
               margin: EdgeInsets.fromLTRB(10, 10, 10, 10),
               color: Colors.white60,
               child: Text('这是一长段文字,这是一长段文字,这是一长段文字,这是一长段文字,这是一长段文字,这是一长段文字'),
               padding: EdgeInsets.fromLTRB(10, 10, 10, 10),
             ),
           ),
         ),
       ),
     ),
   );
 }
}

这里在 body里的组件层级如下:

  • Center:居中组件。

    • Container:没指定大小(通过盒子模型约束控制大小),与父级组件的外边距为左10,上0,右20,下30,颜色为红色。

    • Container:没指定大小,与父级组件的上下左右外边距均为10,内边距上下左右均为10,颜色为白色。

    • Text:显示多行文本,用于展示内边距效果。

    • Container:300 x 300大小,颜色为蓝色,为最外层组件。

运行后的界面如下图所示,可以看到和预期一致。

Flutter 容器盒子模型的使用示例

来源:https://juejin.cn/post/6962698438068666398

标签:Flutter,容器,盒子模型
0
投稿

猜你喜欢

  • 通过Java实现在Word中创建可填充表单

    2023-08-05 21:11:40
  • Flutter SizedBox布局组件Widget使用示例详解

    2022-02-08 18:19:44
  • 字符串转换成枚举类型的方法

    2022-05-14 16:47:31
  • 关于Hibernate的一些学习心得总结

    2022-04-23 23:51:37
  • java实现简单控制台通讯录

    2023-05-24 14:33:20
  • 基于WPF实现代码查看器控件

    2022-10-06 03:32:11
  • maven手动上传jar包示例及图文步骤过程

    2023-11-13 22:10:57
  • JAVA IDEA入门使用手册(新手小白必备)

    2022-10-21 16:31:25
  • Android6.0获取动态权限代码示例

    2022-07-22 10:35:15
  • C#的TimeSpan案例详解

    2023-11-20 11:34:52
  • Java应用EasyExcel工具类

    2023-07-07 18:45:32
  • Idea Jrebel 报错:Cannot reactivate,offline seat in use

    2022-01-11 05:08:22
  • Android实现通用筛选栏

    2021-10-16 05:31:42
  • Kotlin使用协程实现高效并发程序流程详解

    2021-12-27 20:47:21
  • c++ 函数指针相关总结

    2022-09-26 04:42:33
  • Java的MyBatis框架中实现多表连接查询和查询结果分页

    2022-10-29 08:49:21
  • Spring框架七大模块简单介绍

    2023-03-10 10:25:23
  • Java 逻辑运算符中&&与&,||与|的区别

    2021-05-30 15:24:26
  • Android实现极简打开摄像头

    2022-09-10 15:56:51
  • Django之多对多查询与操作方法详解

    2021-08-03 03:21:58
  • asp之家 软件编程 m.aspxhome.com