我的编程空间,编程开发者的网络收藏夹
学习永远不晚

详解如何在Flutter中用小部件创建响应式布局

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

详解如何在Flutter中用小部件创建响应式布局

构建响应式屏幕布局意味着编写一段代码,以响应设备布局的各种变化,因此应用程序会根据设备的屏幕尺寸和形状显示其UI。

在这篇文章中,我们将探讨Flutter中用于屏幕响应的扩展和灵活部件。

由于Flutter的跨平台、单一代码库的能力,了解屏幕管理以防止像柔性溢出错误或糟糕的用户界面设计这样的问题是至关重要的。

我们还将设计一个扩展和灵活部件的演示,并描述它们的属性以及如何在Flutter应用程序中使用它们。

前提条件

为了理解和跟上本教程,您应该具备以下条件。

  • 在您的本地机器上安装Flutter
  • 具有Flutter和Dart的工作知识

使用容器的问题

在Flutter中,一个容器是一个包含多个子小部件的父小部件。它通过宽度、高度、背景颜色和填充以及其他描述符来管理它们。基本上,一个容器是一个盒子,我们可以把内容传进去。

有两个原因可以说明为什么在Flutter中使用容器来创建一个响应式的屏幕布局是不可取的。

首先是RenderFlex的溢出。这是最经常遇到的Flutter框架错误之一;当它发生时,你会看到黄色和黑色的条纹,指示应用程序UI中的溢出区域,此外还有调试控制台的错误信息。

"大屏幕的内容尺寸不足 "只是一个UI错误,由于Flutters的灵活性,内容对于特定的屏幕来说太小或太大。

这两个问题都可以使用 "灵活 "或 "扩展 "小组件来解决,提供更好的UI和开发体验。

展开式小组件的介绍

扩展小组件是一个单子小组件,意味着只能给它分配一个子项。为了更好地优化,它被用在行或列中。

扩展小组件的属性包括child 小组件和flex 小组件。

child 小组件被放置在一个扩展的小组件内,它可以收进行和列。Flex 被用来不均匀地分配child 小组件的内容。

在下面的代码中,我们使用扩大的小组件,将flex 设置为1 ,并使用一个普通的容器来显示扩大的小组件的效果和它的属性。

Expanded(
 flex: 1,
 child: Container(
 color: Colors.red,
 ),
),

灵活小组件的介绍

灵活小组件与 "扩展 "小组件相当相似,但显著的区别在于其属性。灵活小组件用于调整孩子在屏幕中的内容位置。

灵活部件的属性包括fitflex

Fit 控制该属性如何填充可用空间。它有两个选项:FlexFit.Tight ,将其设置为填充可用空间,以及FlexFit.loose ,填充子小组件的剩余可用空间。

就像在 "扩展 "小组件中,flex 被用来不均匀地分配子小组件的内容。

下面的代码使用了一个Flexible widget,其flex 被设置为1 ,适合作为FlexFit.loose ,以及一个具有常规功能的子容器。

Flexible(
   flex: 1,
   fit: FlexFit.loose,
   child: Container(
   height: 100,
    decoration: BoxDecoration(
      borderRadius: BorderRadius.circular(15),
      color: Colors.deepOrange[400],
      ),
    child:Icon(Icons.backpack),
 ),
),

设置一个示例应用程序

在这个演示中,我们将创建一个Flutter示例应用程序,其布局是以行和列显示的内容。

这里有一个gif图,展示了我们将在这篇文章中建立的演示应用程序。

让我们先创建一个Flutter项目目录;在你的终端输入以下命令。

mkdir FlutterApps

接下来,创建一个Flutter项目。

flutter create sample_app

现在,在您选择的任何代码编辑器中打开Flutter项目。

代码执行

将以下代码粘贴到main.dart 文件中。我们首先创建一个名为homepage 的有状态部件。

homepage ,我们将创建两个按钮,将我们引向两个不同的屏幕,以看到在屏幕布局中使用扩展和灵活部件的区别。

Scaffold(
  body: Center(
    child:
      Column(mainAxisAlignment: MainAxisAlignment.center, children: [
 GestureDetector(
  onTap: () {
   Navigator.push(
    context,
    MaterialPageRoute(
     builder: (context) => ExpandedWidget(),
    ),
   );
  },
  child: Container(
    height: 50,
    width: 150,
    decoration: BoxDecoration(
      borderRadius: BorderRadius.circular(10), color: Colors.red),
    child: Center(child: Text("Expanded Widget"))),
 ),
 SizedBox(height: 100),
 GestureDetector(
  onTap: () {
   Navigator.push(
    context,
    MaterialPageRoute(
     builder: (context) => FlexibleWidget(),
    ),
   );
  },
  child: Container(
    height: 50,
    width: 150,
    decoration: BoxDecoration(
      borderRadius: BorderRadius.circular(10),
      color: Colors.teal[700]),
    child: Center(child: Text("Flexible Widget"))),
 )
])));

创建的按钮是简单的容器,里面有一些decorationcolortext 小部件,用一个手势检测器包裹起来,使我们能够使用onTap 属性来引导到ExpandedWidget()FlexibleWidget() 屏幕。

扩展的小部件例子

首先,创建一个名为expanded.dart 的文件。

touch expanded.dart

接下来,将以下代码粘贴到文件中。在代码中,我们创建了一个无状态的小部件,以使用flex 属性编写我们的例子。

class ExpandedWidget extends StatelessWidget {
 const ExpandedWidget({Key? key}) : super(key: key);
 @override
 Widget build(BuildContext context) {
  return Scaffold(
    appBar: AppBar(
     leading: GestureDetector(
       onTap: () {
        Navigator.pop(context);
       },
       child: Icon(Icons.arrow_back_ios_new)),
    ),
    body: Padding(
     padding: const EdgeInsets.symmetric(horizontal: 15),
     child: Column(
      mainAxisAlignment: MainAxisAlignment.spaceAround,
      children: [
       Column(
        children: [
         Text("With Flex"),
         Container(
          height: 100,
          child: Row(
           children: [
            Expanded(
             flex: 1,
             child: Container(
              color: Colors.red,
             ),
            ),
            Expanded(
             flex: 2,
             child: Container(
              color: Colors.deepOrange[400],
             ),
            ),
            Expanded(
             flex: 3,
             child: Container(
              color: Colors.purpleAccent,
             ),
            )
           ],
          ),
         ),
        ],
       ),
       Column(
        children: [
         Text("Without Flex"),
         Container(
          height: 100,
          child: Row(
           children: [
            Expanded(
             child: Container(
              color: Colors.red,
             ),
            ),
            Expanded(
             child: Container(
              color: Colors.deepOrange[400],
             ),
            ),
            Expanded(
             child: Container(
              color: Colors.purpleAccent,
             ),
            )
           ],
          ),
         ),
        ],
       ),
      ],
     ),
    ));
 }
}

首先,我们返回一个脚手架,以便我们可以使用appbarbody 属性。接下来,在appbar ,我们创建了一个返回按钮,这样我们就可以返回到前一个屏幕。

接着是正文,我们使用了两列,一列在顶部,另一列在按钮处将它们间隔开来;在每一列中,我们有一段文字描述它是有还是没有flex 。在它下面,我们使用三个有或没有flex 的扩展部件和一个分配不同颜色的容器创建了一个行。

下面的图片显示了应用和不应用flex 的布局。

灵活部件的例子

首先,创建一个名为flexible.dart 的文件。

touch flexible.dart

接下来,将以下代码粘贴到文件中。

class FlexibleWidget extends StatelessWidget {
 const FlexibleWidget({Key? key}) : super(key: key);
 @override
 Widget build(BuildContext context) {
  return Scaffold(
   appBar: AppBar(
    leading: GestureDetector(
      onTap: () {
       Navigator.pop(context);
      },
      child: Icon(Icons.arrow_back_ios_new)),
   ),
   body: Padding(
    padding: const EdgeInsets.symmetric(horizontal: 10),
    child: Column(
     mainAxisAlignment: MainAxisAlignment.spaceAround,
     children: [
      Column(
       children: [
        Text("Flexfit.loose"),
        Row(
         mainAxisAlignment:MainAxisAlignment.center,
         children: [
          Flexible(
           flex: 1,
           fit: FlexFit.loose,
           child: Container(
            height: 100,
            decoration: BoxDecoration(
             borderRadius: BorderRadius.circular(15),
             color: Colors.deepOrange[400],
            ),
            child:Icon(Icons.backpack),
           ),
          ),
          SizedBox(
           width: 10,
          ),
          Flexible(
           flex: 1,
           fit: FlexFit.loose,
           child: Container(
            height: 100,
            decoration: BoxDecoration(
             borderRadius: BorderRadius.circular(15),
             color: Colors.deepOrange[400],
            ),
            child:Icon(Icons.backpack),
           ),
          )
         ],
        )
       ],
      ),
      Column(
       children: [
        Text("Flexfit.tight"),
        Row(
         children: [
          Flexible(
           flex: 1,
           fit: FlexFit.tight,
           child: Container(
             height: 100,
           decoration: BoxDecoration(
            borderRadius: BorderRadius.circular(15),
              color: Colors.purpleAccent,
           ),
           child:Icon(Icons.backpack),
           ),
          ),
          SizedBox(
           width: 10,
          ),
          Flexible(
           flex: 1,
           fit: FlexFit.tight,
           child: Container(
             height: 100,
            decoration: BoxDecoration(
             borderRadius: BorderRadius.circular(15),
             color: Colors.purpleAccent,
            ),
            child:Icon(Icons.backpack),
           ),
          )
         ],
        )
       ],
      )
     ],
    ),
   ),
  );
 }
}

在代码中,我们创建了一个无状态的小部件,FlexibleWidget 。在它里面,我们创建了两行灵活部件的内容。在第一行,我们使用flexfit.loose ,在第二行,我们使用flexfit.tight 。有了这个,图标将填补孩子所提供的可用空间。

下面的图片显示了这样的布局,flexfit.loose ,使用了孩子提供的最小空间,flexfit.tight ,填补了孩子提供的可用空间。

扩大的和灵活的部件之间的区别

就像我之前指出的那样,这些小组件的主要区别在于它们的属性。展开的小组件只有childflex 属性,如果误用的话,这可能是一个限制。相比之下,灵活的小组件有更多的属性;这使得使用灵活,因此而得名。

总结

在这篇文章中,我们了解了使用 "扩展 "和 "灵活 "小组件的响应式屏幕布局。我们首先介绍了使用容器创建响应式屏幕布局时必然会出现的潜在问题,然后介绍了解决方案:扩展的和灵活的部件。我们介绍了它们的属性、相似性、差异性,最重要的是,我们还介绍了一个实际操作的例子。

以上就是详解如何在Flutter中用小部件创建响应式布局的详细内容,更多关于Flutter响应式布局的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

详解如何在Flutter中用小部件创建响应式布局

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何使用CSS属性创建响应式布局

如何使用CSS属性创建响应式布局随着移动设备的普及和多终端的兴起,响应式布局越来越受到开发者的重视。通过使用CSS属性,我们可以轻松地实现响应式布局,让网页在不同终端上都能够达到良好的显示效果。本文将介绍如何使用CSS属性创建响应式布局,并
如何使用CSS属性创建响应式布局
2023-11-18

如何使用Css Flex 弹性布局创建响应式卡片布局

在现代网页设计中,响应式布局是一种必不可少的设计方式。而弹性布局(Flexbox)是一种强大而灵活的布局模型,可以让我们更轻松地创建响应式布局。本文将介绍如何使用Css Flex 弹性布局创建一个简单的响应式卡片布局,并提供具体的代码示例。
2023-10-21

如何使用HTML和CSS创建一个响应式商品详情布局

在当今移动互联网的时代,响应式网页设计已经成为了现代网页设计的标配。而商品详情页作为电商网站中重要的页面之一,其响应式设计显得尤为重要。本文将介绍如何使用HTML和CSS创建一个响应式商品详情布局,并附上具体的代码示例。HTML 结构首先,
2023-10-21

如何使用HTML和CSS创建一个响应式图库布局

引言:随着移动设备的普及,响应式设计成为了网页设计的重要考虑因素之一。而在开发一个图库网站时,如何设计一个兼具美观和响应式布局的页面,将成为重要的问题。本文将详细讨论如何使用HTML和CSS来创建一个响应式图库布局,并且提供具体的代码示例。
2023-10-21

如何使用HTML和CSS创建一个响应式博客布局

在当今互联网时代,博客已经成为人们分享知识、经验和故事的重要平台。设计一个吸引人且具有响应式布局的博客,可以让你的内容更好地展示在不同尺寸和设备上,提升用户体验。本文将介绍如何使用HTML和CSS来创建一个响应式博客布局,同时提供具体的代码
2023-10-21

如何使用HTML和CSS创建一个响应式表格布局

如何使用HTML和CSS创建一个响应式表格布局HTML是一种用于构建网页结构的标记语言,而CSS则用于设置网页的样式和布局。在网页设计中,表格是一种常见的元素,用于以表格形式展示数据。本文将介绍如何使用HTML和CSS来创建一个响应式的表格
2023-10-27

如何使用HTML和CSS创建一个响应式卡片瀑布流布局

如何使用HTML和CSS创建一个响应式卡片瀑布流布局在当今的网页设计中,响应式设计已经成为一种必需品。随着越来越多的用户在各种设备上访问互联网,我们需要确保网页能够良好地适应不同的屏幕尺寸和设备类型。本文将向您介绍如何使用HTML和CSS创
2023-10-24

如何使用HTML和CSS创建一个响应式图片墙布局

如何使用HTML和CSS创建一个响应式图片墙布局引言:随着移动互联网的普及,响应式设计成为了网页设计的重要标准。在网页设计中,图片墙布局是常见的一种布局形式,它可以以瀑布流的形式展示不同尺寸的图片。本文将介绍如何使用HTML和CSS创建一个
2023-10-25

如何使用HTML和CSS创建一个响应式轮播图布局

在现代的网页设计中,轮播图是一个常见的元素。它能够吸引用户的注意力,展示多个内容或图片,并且能够自动切换。在本文中,我们将介绍如何使用HTML和CSS创建一个响应式的轮播图布局。首先,我们需要创建一个基本的HTML结构,并添加所需的CSS样
2023-10-21

如何使用HTML和CSS创建一个响应式会员卡布局

如何使用HTML和CSS创建一个响应式会员卡布局在当今社会,会员卡已成为商家吸引客户、增加销售额的一种重要手段。然而,在设计会员卡布局时,我们经常会面临一个重要问题:如何在不同设备上(如电脑、手机、平板电脑)展示出完美的响应式效果?本文将教
2023-10-24

如何使用HTML和CSS创建一个响应式卡片墙布局

如何使用HTML和CSS创建一个响应式卡片墙布局在现代网页设计中,响应式布局是一项非常重要的技术。通过使用HTML和CSS,我们可以创建一个响应式的卡片墙布局,以适应不同屏幕尺寸的设备。下面将详细介绍如何使用HTML和CSS创建一个简单的响
2023-10-25

如何使用HTML和CSS创建一个响应式时光轴布局

如何使用HTML和CSS创建一个响应式时光轴布局时光轴布局是一种独特的页面布局方式,能够将内容按照时间顺序展示,非常适合用于展示历史事件、个人履历或者项目进展等。本文将介绍如何使用HTML和CSS来创建一个响应式的时光轴布局,并提供具体的代
2023-10-26

如何使用HTML和CSS创建一个响应式导航栏布局

导航栏是网站中非常重要的一部分,它可以帮助用户快速导航到想要的页面。在移动设备越来越普及的今天,响应式导航栏布局尤为重要,以适应不同屏幕尺寸的设备。本文将介绍如何使用HTML和CSS创建一个简单的响应式导航栏布局,并提供具体的代码示例。HT
2023-10-21

如何使用HTML和CSS创建一个响应式模态框布局

在现代网页设计中,模态框(Modal Box)是一个常见的元素,用于在网页上显示额外的内容,如提示、登录框、图片展示等。在本篇文章中,我们将学习如何使用HTML和CSS创建一个响应式的模态框布局,并提供具体的代码示例。首先,我们需要创建一个
2023-10-21

详解Css Flex 弹性布局在响应式图片展示中的应用

过去,我们在网页上展示图片时,经常遇到的一个问题是如何使图片在不同屏幕尺寸下保持良好的显示效果。传统的CSS布局方法无法很好地解决这个问题,而CSS Flex弹性布局则是一种有效的解决方案。本文将详细介绍CSS Flex弹性布局在响应式图片
2023-10-21

如何使用HTML和CSS创建一个响应式图片画廊布局

在现代的网页设计中,响应式设计已经成为一个非常重要的概念。随着移动设备的普及,人们对于在不同设备上浏览网页的需求也愈发增加。在本文中,我将详细介绍如何使用HTML和CSS创建一个响应式的图片画廊布局。首先,我们需要准备一些HTML结构来构建
2023-10-21

如何使用HTML和CSS创建一个响应式导航菜单布局

导航菜单是网站设计中非常重要的一个元素,它能够帮助用户快速浏览并导航到网站的不同部分。随着移动设备的普及,响应式设计也成为了必要的要素之一,因为在不同大小的屏幕上,导航菜单的布局和样式需要调整以适应不同设备。在本文中,我将向您展示如何使用H
2023-10-21

如何使用HTML和CSS创建一个响应式会员注册布局

随着移动设备的普及,网站的响应式设计越来越重要。为了满足不同设备屏幕尺寸的需求,我们需要创建一个能够自适应调整布局的会员注册页面。本文将介绍如何使用HTML和CSS创建一个响应式的会员注册布局,并提供具体的代码示例。创建HTML结构首先,我
2023-10-21

如何使用HTML和CSS创建一个响应式图片网格布局

如何使用HTML和CSS创建一个响应式图片网格布局在当今的互联网时代,图片占据了网络内容的重要一部分。为了展示各种类型的图片,我们需要一个有效且美观的网格布局。在本文中,我们将学习如何使用HTML和CSS创建一个响应式的图片网格布局。首先,
2023-10-27

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录