当前位置: 首页 > news >正文

【Flutter】页面布局:线性布局(Row 和 Column)

在 Flutter 中,布局(Layout)是应用开发的核心之一。通过布局组件,开发者可以定义应用中的控件如何在屏幕上排列。RowColumn 是 Flutter 中最常用的两种线性布局方式,用于水平和垂直排列子组件。在本教程中,我们将详细介绍这两个布局组件的用法,并通过实例帮助理解如何使用它们来构建灵活、响应式的用户界面。

线性布局简介

线性布局是指组件按一定方向依次排列,方向可以是水平(Row)或者垂直(Column)。在 Flutter 中,Row 用于水平排列,Column 用于垂直排列。它们都可以包含多个子组件,按照一定规则依次布局。

RowColumn 的基本属性:

  • children: 这是它们最主要的属性,用于指定要排列的子组件,通常是一个 Widget 的列表(List<Widget>)。
  • mainAxisAlignment: 控制主轴(Row 的主轴是水平轴,Column 的主轴是垂直轴)上的对齐方式。
  • crossAxisAlignment: 控制交叉轴(Row 的交叉轴是垂直轴,Column 的交叉轴是水平轴)上的对齐方式。
  • mainAxisSize: 决定主轴的尺寸大小,是占满可用空间还是仅包裹内容。

Row:水平布局

Row 是一个水平方向的布局组件,它允许子组件在水平轴上依次排列。通过 Row,你可以很容易地实现按钮栏、图标栏等常见的水平布局场景。

Row 基本示例

import 'package:flutter/material.dart';void main() {runApp(MyApp());
}class MyApp extends StatelessWidget {Widget build(BuildContext context) {return MaterialApp(home: Scaffold(appBar: AppBar(title: Text('Row 示例')),body: Row(children: <Widget>[Icon(Icons.home, size: 40, color: Colors.blue),Icon(Icons.favorite, size: 40, color: Colors.red),Icon(Icons.settings, size: 40, color: Colors.green),],),),);}
}

在这个例子中,Row 组件水平排列了三个图标。Row 中的 children 属性是一个 List<Widget>,每个子组件会按顺序从左到右进行排列。

Row 主要属性详解

  1. mainAxisAlignment
    控制子组件在主轴(水平方向)上的对齐方式。mainAxisAlignment 提供了几种常用的对齐方式:

    • MainAxisAlignment.start: 子组件从主轴起始位置排列(默认)。
    • MainAxisAlignment.end: 子组件从主轴结束位置排列。
    • MainAxisAlignment.center: 子组件在主轴上居中排列。
    • MainAxisAlignment.spaceBetween: 子组件在主轴上平均分布,首尾组件紧贴两端,中间均匀间隔。
    • MainAxisAlignment.spaceAround: 子组件在主轴上均匀分布,每个组件两侧有相同的间距。
    • MainAxisAlignment.spaceEvenly: 子组件均匀分布,子组件之间以及两端的间距都相同。

    示例

    Row(mainAxisAlignment: MainAxisAlignment.spaceEvenly,children: <Widget>[Icon(Icons.home, size: 40),Icon(Icons.favorite, size: 40),Icon(Icons.settings, size: 40),],
    )
    
  2. crossAxisAlignment
    控制子组件在交叉轴(垂直方向)上的对齐方式:

    • CrossAxisAlignment.start: 子组件在交叉轴起始位置对齐。
    • CrossAxisAlignment.end: 子组件在交叉轴结束位置对齐。
    • CrossAxisAlignment.center: 子组件在交叉轴上居中对齐(默认)。
    • CrossAxisAlignment.stretch: 拉伸子组件以占满交叉轴。

    示例

    Row(crossAxisAlignment: CrossAxisAlignment.center,children: <Widget>[Icon(Icons.home, size: 40),Icon(Icons.favorite, size: 60),Icon(Icons.settings, size: 40),],
    )
    
  3. mainAxisSize
    控制 Row 在主轴方向的尺寸大小,默认是 MainAxisSize.max,即尽可能占用主轴的全部空间。如果只想让 Row 根据子组件的宽度进行调整,可以设置为 MainAxisSize.min

    示例

    Row(mainAxisSize: MainAxisSize.min,children: <Widget>[Icon(Icons.home, size: 40),Icon(Icons.favorite, size: 40),Icon(Icons.settings, size: 40),],
    )
    

Column:垂直布局

Row 类似,Column 用于将子组件按垂直方向排列。它适用于需要将多个组件上下堆叠的场景,例如表单、列表项等。

Column 基本示例

import 'package:flutter/material.dart';void main() {runApp(MyApp());
}class MyApp extends StatelessWidget {Widget build(BuildContext context) {return MaterialApp(home: Scaffold(appBar: AppBar(title: Text('Column 示例')),body: Column(children: <Widget>[Text('Flutter', style: TextStyle(fontSize: 24)),Icon(Icons.favorite, size: 50, color: Colors.red),Text('Dart', style: TextStyle(fontSize: 24)),],),),);}
}

在此示例中,Column 将三个子组件按垂直方向依次排列。与 Row 类似,Column 也有一些控制排列和对齐的属性。

Column 主要属性详解

  1. mainAxisAlignment
    控制子组件在主轴(垂直方向)上的对齐方式,属性和 Row 中的 mainAxisAlignment 用法相同。

    示例

    Column(mainAxisAlignment: MainAxisAlignment.spaceAround,children: <Widget>[Text('上方文本', style: TextStyle(fontSize: 24)),Icon(Icons.favorite, size: 50),Text('下方文本', style: TextStyle(fontSize: 24)),],
    )
    
  2. crossAxisAlignment
    控制子组件在交叉轴(水平方向)上的对齐方式,属性与 Row 中的 crossAxisAlignment 类似。

    示例

    Column(crossAxisAlignment: CrossAxisAlignment.center,children: <Widget>[Text('文本1', style: TextStyle(fontSize: 24)),Text('文本2', style: TextStyle(fontSize: 24)),],
    )
    
  3. mainAxisSize
    控制 Column 在主轴方向的尺寸大小,默认是 MainAxisSize.max,即尽可能占用垂直方向的全部空间。如果只想让 Column 根据子组件的高度进行调整,可以设置为 MainAxisSize.min

    示例

    Column(mainAxisSize: MainAxisSize.min,children: <Widget>[Text('文本1', style: TextStyle(fontSize: 24)),Text('文本2', style: TextStyle(fontSize: 24)),],
    )
    

使用 Expanded 调整布局

Expanded 是一个非常实用的组件,它可以让某个子组件在主轴方向上占据尽可能多的空间。在 RowColumn 布局中,使用 Expanded 可以灵活调整子组件的大小和占比。

示例:使用 Expanded

Row(children: <Widget>[Expanded(child: Container(color: Colors.red,height: 50,),),Container(color: Colors.green,width: 100,height: 50,),],
)

在这个示例中,Expanded 让第一个子组件(红色容器)在 Row 的水平方向上占据尽可能多的空间,而第二个子组件(绿色容器)固定宽度为 100 像素。

RowColumn 组合使用

在实际开发中,你经常需要将 `

RowColumn组合使用来创建复杂的布局结构。通过将RowColumn` 嵌套在一起,可以轻松构建出网格布局、表单布局等复杂界面。

示例:嵌套使用 RowColumn

Column(children: <Widget>[Row(mainAxisAlignment: MainAxisAlignment.spaceEvenly,children: <Widget>[Icon(Icons.home, size: 40),Icon(Icons.favorite, size: 40),Icon(Icons.settings, size: 40),],),Row(mainAxisAlignment: MainAxisAlignment.spaceEvenly,children: <Widget>[Text('Home'),Text('Favorite'),Text('Settings'),],),],
)

这个示例展示了如何将 RowColumn 组合使用,一个 Row 中放置了图标,另一个 Row 中放置了对应的文本。

总结

RowColumn 是 Flutter 中最基础、最常用的布局组件,它们分别用于水平和垂直排列子组件。通过合理地使用这些线性布局组件,并结合属性如 mainAxisAlignmentcrossAxisAlignmentExpanded,开发者可以轻松构建出灵活、响应式的用户界面。

掌握 RowColumn 的使用技巧,是 Flutter 布局系统中非常重要的一部分。在后续的开发中,随着需求的复杂化,线性布局通常会与其他布局组件如 StackFlex 等组合使用,构建出更加复杂的界面。

相关文章:

【Flutter】页面布局:线性布局(Row 和 Column)

在 Flutter 中&#xff0c;布局&#xff08;Layout&#xff09;是应用开发的核心之一。通过布局组件&#xff0c;开发者可以定义应用中的控件如何在屏幕上排列。Row 和 Column 是 Flutter 中最常用的两种线性布局方式&#xff0c;用于水平和垂直排列子组件。在本教程中&#xf…...

C语言巨难题:执行操作可获得的最大总奖励 I(C语言版)

1.题目&#xff1a; 给你一个整数数组 rewardValues&#xff0c;长度为 n&#xff0c;代表奖励的值。 最初&#xff0c;你的总奖励 x 为 0&#xff0c;所有下标都是 未标记 的。你可以执行以下操作 任意次 &#xff1a; 从区间 [0, n - 1] 中选择一个 未标记 的下标 i。如果…...

【力扣】GO解决子序列相关问题

文章目录 一、引言二、动态规划方法论深度提炼子序列问题的通用解法模式 三、通用方法论应用示例&#xff1a;最长递增子序列&#xff08;LeetCode题目300&#xff09;Go 语言代码实现 四、最长连续递增序列&#xff08;LeetCode题目674&#xff09;Go 语言代码实现 五、最长重…...

Ubuntu20.04安装VM tools并实现主机和虚拟机之间文件夹共享

1、Ubuntu20.04安装VM tools 参考这个&#xff0c;很详细&#xff1a;Ubuntu 20.04 安装 VMwareTools 教程 2、实现主机与VMware虚拟机共享文件夹 设置共享文件夹参考&#xff1a;windows和虚拟机互传文件的三种方式 挂载操作参考&#xff1a;主机与VMware虚拟机共享文件夹&…...

Linux 学习笔记(十七)—— 文件系统

终极目标&#xff1a;理解 inode 和 软硬连接&#xff1b; 文件系统&#xff1a;Ext2; 文件 文件内容 文件属性; ——> 磁盘上存储的文件 存储的文件内容 存储的文件属性&#xff1b; Linux系统中&#xff1a;文件内容使用数据块存储&#xff0c;文件属性使用inode(固定…...

【计算机网络 - 基础问题】每日 3 题(五十八)

✍个人博客&#xff1a;https://blog.csdn.net/Newin2020?typeblog &#x1f4e3;专栏地址&#xff1a;http://t.csdnimg.cn/fYaBd &#x1f4da;专栏简介&#xff1a;在这个专栏中&#xff0c;我将会分享 C 面试中常见的面试题给大家~ ❤️如果有收获的话&#xff0c;欢迎点赞…...

Netty入门基础:IO模型中BIO\NIO概念及区别【附演示代码】

文章目录 &#x1f600;BIO&#x1f4a2;实战demo &#x1f308;NIO&#x1f3cd;Buffer核心属性核心方法 &#x1f397;Channel&#x1f388;Selector核心方法 &#x1f9e8;实战demo &#x1f3a8;粘包与半包 &#x1f600;BIO 传统IO模型&#xff0c;同步阻塞&#xff0c;每…...

vue2 使用环境变量

一. 在根目录下创建.env.xxx文件 .env 基础系统变量&#xff0c;无论何种环境&#xff0c;都可使用其中配置的值&#xff0c;其他环境中的变量会覆盖.env中的同名变量。 .env.development 开发环境 .env.production 生产环境 .env.staging 测试环境 二. 内容格式 vue2 使用是以…...

数据预处理

继续提取代码片段&#xff1a; 12. **导入iris数据集并查看前5行数据**&#xff1a; python from sklearn.datasets import load_iris iris load_iris() X iris.data print(iris数据集的维度为:, X.shape) print(iris数据集的前5行数据为:\n, X[:5]) …...

django宠物领养管理系统-计算机毕业设计源码26858

目录 1 绪论 1.1 选题背景与意义 1.2国内外研究现状 1.3论文结构与章节安排 2系统分析 2.1 可行性分析 2.2 系统流程分析 2.2.1 数据流程 3.3.2 业务流程 2.3 系统功能分析 2.3.1 功能性分析 2.3.2 非功能性分析 2.4 系统用例分析 2.5本章小结 3 系统总体设计 3…...

使用TeamViewer远程局域网内的两台电脑

有个场景&#xff0c;有人还不知道TV可以局域网操作&#xff0c;记录一下。 主要就是修改设置&#xff0c;将取消激活改为接受 然后输入受控端的ip即可...

GUI简介、Swing的常用组件、java程序的运行过程、class文件、JAR、runable_jar、双括号初始化

GUI简介 GUI&#xff1a;图形用户界面&#xff0c;在计算机中采用图形的方式显示用户界面 java的GUI开发 AWT&#xff1a;java最早推出的GUI编程开发包&#xff0c;界面风格跟随操作系统SWT&#xff1a;eclipse就是java使用SWT开发的Swing&#xff1a;在AWT的基础上扩充了功能…...

@Autowired和@Resource和getBean()区别

今天遇到一个对我来说很奇葩的错误&#xff0c;我想在Service中注入bean&#xff0c;我这里使用了Autowired和Resource都不能注入&#xff0c;导致初始化失败&#xff0c;使用了getBean()方法就可以注入。从来没有遇到过这个问题。后来我查询了一下&#xff0c;才明白了原理。我…...

Merlion笔记(四):添加一个新的预测模型

文章目录 1 模型配置类2 模型类3 运行模型&#xff1a;一个简单的例子4 可视化5 定量评估6 定义一个基于预测器的异常检测器 本文提供了一个示例&#xff0c;展示如何向 Merlion 添加一个新的预测模型,遵循 CONTRIBUTING.md 中的说明。建议在阅读本篇文章之前&#xff0c;先查…...

【论文阅读】ESRGAN

学习资料 论文题目&#xff1a;增强型超分辨率生成对抗网络&#xff08;ESRGAN: Enhanced Super-Resolution Generative Adversarial Networks&#xff09;论文地址&#xff1a;[1809.00219] ESRGAN&#xff1a;增强型超分辨率生成对抗网络代码&#xff1a;xinntao / ESRGAN&am…...

电脑异常情况总结

文章目录 笔记本无症状息屏黑屏 笔记本无症状息屏黑屏 &#x1f34e; 问题描述&#xff1a; 息屏导致黑屏&#xff1b;依次操作计算机--》右键--》管理--》事件查看器--》Windows日志--》系统&#xff1b;从息屏到异常黑屏之间出现了很多错误&#xff0c;如下&#xff1a;事件…...

[项目详解][boost搜索引擎#1] 概述 | 去标签 | 数据清洗 | scp

目录 一、前言 二、项目的相关背景 三、搜索引擎的宏观原理 四、搜索引擎技术栈和项目环境 五、正排索引 VS 倒排索引--原理 正排索引 分词 倒排索引 六、编写数据去除标签和数据清洗模块 Parser 1.数据准备 parser 编码 1.枚举文件 EnumFile 2.去标签ParseHtml(…...

PL/I语言的起源?有C语言,有B语言和A语言吗?为什么shell脚本最开始可能有#!/bin/bash字样?为什么不支持嵌套注释?

PL/I语言的起源 在20世纪50~60年代&#xff0c;当时主流的编程语言是COBOL/FORTRAN/ALGOL等&#xff0c;IBM想要设计一门通用的编程语言&#xff0c;已有的编程语言无法实现此要求&#xff0c;故想要设计一门新语言&#xff0c;即是PL/I. PL/I是Programming Language/One的缩写…...

gin入门教程(3):创建第一个 HTTP 服务器

首先设置golang github代理&#xff0c;可解决拉取git包的时候&#xff0c;无法拉取的问题&#xff1a; export GOPROXYhttps://goproxy.io再查看自己的go版本&#xff1a; go version我这里的版本是&#xff1a;go1.23.2 linux/arm64 准备工作做好之后就可以进行开发了 3.…...

Vue+ECharts+iView实现大数据可视化大屏模板

Vue数据可视化 三个大屏模板 样式还是比较全的 包括世界地图、中国地图、canvas转盘等 项目演示&#xff1a; 视频&#xff1a; vue大数据可视化大屏模板...

Alibaba DASD-4B Thinking 对话工具 网络故障智能诊断:从 403 Forbidden 到连接超时

Alibaba DASD-4B Thinking 对话工具 网络故障智能诊断&#xff1a;从 403 Forbidden 到连接超时 遇到网络问题&#xff0c;比如网页打不开显示“403 Forbidden”&#xff0c;或者一直转圈最后提示“连接超时”&#xff0c;是不是感觉特别头疼&#xff1f;以前遇到这种问题&…...

实战解密il2cpp的global-metadata.dat文件:用IDA和VS Code逆向分析技巧

实战解密il2cpp的global-metadata.dat文件&#xff1a;用IDA和VS Code逆向分析技巧 在移动应用安全研究和游戏逆向工程领域&#xff0c;il2cpp作为Unity引擎的核心组件&#xff0c;其生成的global-metadata.dat文件承载着关键的类型信息和运行时元数据。本文将深入探讨如何通过…...

数据结构从入门到劝退?我用王者荣耀段位比喻线性表操作

数据结构王者之路&#xff1a;用游戏段位解锁线性表操作精髓 青铜段位&#xff1a;初识数据结构与线性表 刚接触数据结构的新手&#xff0c;就像刚注册游戏账号的青铜玩家。在这个阶段&#xff0c;我们需要理解最基础的概念——什么是数据结构&#xff1f;简单来说&#xff0c;…...

Qwen3-32B-Chat私有化部署案例:金融研报摘要生成服务API封装

Qwen3-32B-Chat私有化部署案例&#xff1a;金融研报摘要生成服务API封装 1. 项目背景与价值 在金融行业&#xff0c;每天都会产生大量研究报告&#xff0c;分析师需要花费大量时间阅读和提炼关键信息。传统的人工摘要方式效率低下&#xff0c;且难以保证一致性。Qwen3-32B作为…...

Vue项目PC端自适应终极方案:px2rem-loader+postcss-px2rem保姆级教程

Vue项目PC端自适应终极方案&#xff1a;px2rem-loaderpostcss-px2rem保姆级教程 在当今多设备、多分辨率的互联网环境下&#xff0c;前端开发者面临的最大挑战之一就是如何确保网站在不同尺寸的屏幕上都能完美呈现。特别是对于企业级Vue项目&#xff0c;PC端的自适应需求往往比…...

Qwen-Image-2512企业级部署方案:高可用架构设计

Qwen-Image-2512企业级部署方案&#xff1a;高可用架构设计 1. 企业级部署需求分析 现在越来越多的企业开始将AI图像生成能力集成到自己的业务系统中&#xff0c;但真正要在生产环境稳定运行&#xff0c;可不是简单装个软件就能解决的。特别是像Qwen-Image-2512这样的高质量文…...

Vibe Coding实战:如何用AI生成你的第一个React天气应用(附完整Prompt模板)

Vibe Coding实战&#xff1a;用AI构建React天气应用的完整指南 从零开始的AI编程体验 去年夏天&#xff0c;我尝试用传统方式开发一个天气应用&#xff0c;花了整整三周时间调试API接口和React组件状态管理。而今年&#xff0c;借助Vibe Coding技术&#xff0c;同样的项目我只用…...

egoShieldTimeLapse:基于STM32的延时摄影运动控制库

1. 项目概述egoShieldTimeLapse 是专为 uStepper egoShield 硬件平台设计的开源时间 lapse&#xff08;延时摄影&#xff09;控制库&#xff0c;由 ON Development 开发并维护。该库并非通用型电机控制中间件&#xff0c;而是面向特定工业级运动控制场景的垂直解决方案——将高…...

Qwen3-14B-Int4-AWQ量化原理浅析:INT4与AWQ技术如何实现高性能推理

Qwen3-14B-Int4-AWQ量化原理浅析&#xff1a;INT4与AWQ技术如何实现高性能推理 1. 为什么需要模型量化 大语言模型在带来强大能力的同时&#xff0c;也面临着巨大的计算和存储开销。以Qwen3-14B为例&#xff0c;原始FP16格式的模型需要占用约28GB显存&#xff0c;这对大多数消…...

WPS集成MathType:一键配置VBA环境全攻略

1. 为什么需要WPS集成MathType&#xff1f; 对于经常需要编辑数学公式的科研人员、教师和学生来说&#xff0c;MathType无疑是最好用的公式编辑器之一。但很多人在使用WPS时会发现&#xff0c;默认情况下WPS并不能直接调用MathType&#xff0c;每次都要手动复制粘贴公式&#x…...