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

 更新时间:2021年05月19日 11:46:01   作者:岛上码农  
在网页开发中,有盒子模型,号称统一三端的 Flutter 也不例外,而且和 HTML 的盒子模型几乎是一样的,本篇文章通过简单的例子说明一下 Flutter 的盒子模型,方便以后再做界面时可以更好的理解布局。
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

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

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:300 x 300大小,颜色为蓝色,为最外层组件。
      • Container:没指定大小(通过盒子模型约束控制大小),与父级组件的外边距为左10,上0,右20,下30,颜色为红色。
      • Container:没指定大小,与父级组件的上下左右外边距均为10,内边距上下左右均为10,颜色为白色。
      • Text:显示多行文本,用于展示内边距效果。

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

以上就是Flutter 容器盒子模型的使用示例的详细内容,更多关于Flutter 容器的盒子模型的资料请关注程序员之家其它相关文章!

相关文章

  • Android多点触控技术实战 针对图片自由缩放和移动

    Android多点触控技术实战 针对图片自由缩放和移动

    这篇文章主要为大家详细介绍了Android多点触控技术实战,自由地对图片进行缩放和移动,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • android设备不识别awk命令 缺少busybox怎么办

    android设备不识别awk命令 缺少busybox怎么办

    这篇文章主要为大家详细介绍了android设备不识别awk命令,缺少busybox的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • android实现九宫格程序

    android实现九宫格程序

    这篇文章主要为大家详细介绍了android实现九宫格程序,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-06-06
  • Android开发之删除项目缓存的方法

    Android开发之删除项目缓存的方法

    这篇文章主要介绍了Android开发之删除项目缓存的方法,结合实例形式分析了Android开发中关于缓存的设置与删除技巧,需要的朋友可以参考下
    2016-02-02
  • Android编程之短信列表的时间显示实例分析

    Android编程之短信列表的时间显示实例分析

    这篇文章主要介绍了Android编程之短信列表的时间显示,实例分析了Android中短信列表的时间显示及具体注意事项,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • Android实现底部弹出按钮菜单升级版

    Android实现底部弹出按钮菜单升级版

    这篇文章主要为大家详细介绍了Android实现底部弹出按钮菜单的升级版,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-10-10
  • Android监听Home键实例详解

    Android监听Home键实例详解

    这篇文章主要介绍了Android监听Home键的方法,结合实例形式详细分析了Android编程实现监听Home键的具体步骤与相关功能代码,需要的朋友可以参考下
    2016-02-02
  • Android自定义wheelview实现滚动日期选择器

    Android自定义wheelview实现滚动日期选择器

    这篇文章主要为大家详细介绍了Android自定义wheelview实现滚动日期选择器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-07-07
  • Android九宫格手势密码代码设计

    Android九宫格手势密码代码设计

    这篇文章主要为大家详细介绍了Android九宫格手势密码的代码设计思路,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • Android开发之DatePicker和TimePicker实现选择日期时间功能示例

    Android开发之DatePicker和TimePicker实现选择日期时间功能示例

    这篇文章主要介绍了Android开发之DatePicker和TimePicker实现选择日期时间功能,结合实例形式分析了Android DatePicker和TimePicker组件的功能、常用函数、布局及日期时间选择相关操作技巧,需要的朋友可以参考下
    2019-03-03

最新评论

?


http://www.vxiaotou.com