news 2026/4/3 4:48:51

Flutter 零基础入门(二十八):ListView —— 最常用的页面结构

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Flutter 零基础入门(二十八):ListView —— 最常用的页面结构

Flutter 零基础入门(二十八):ListView —— 最常用的页面结构

在上一篇中,我们彻底搞懂了:

  • StatefulWidget 的生命周期
  • initState / build / dispose
  • Flutter 页面是如何“活起来”的

从这一篇开始,我们进入Flutter 业务开发的核心场景

列表页面

几乎所有 App,80% 的页面都是“列表”。


一、为什么 ListView 这么重要?

真实 App 中常见的页面:

  • 新闻列表
  • 商品列表
  • 聊天记录
  • 设置页
  • 用户列表

📌 它们本质上都是:

一列可以滚动的 Widget


二、ListView 是什么?

在 Flutter 中:

ListView 是一个可滚动的 Widget 列表

特点:

  • 支持滚动
  • 自动处理溢出
  • 适合纵向内容很多的页面

三、最简单的 ListView

ListView(children:[Text('第一项'),Text('第二项'),Text('第三项'),],)

效果:

  • 自动纵向排列
  • 超出屏幕可以滚动

四、ListView + ListTile(入门必会)

1️⃣ ListTile 是什么?

ListTile是 Flutter 提供的标准列表项组件

ListTile( title: Text('标题'), )

2️⃣ 一个完整 ListTile

ListTile( leading: Icon(Icons.person), title: Text('用户名'), subtitle: Text('这是副标题'), trailing: Icon(Icons.arrow_forward_ios), )

这是非常标准、非常常见的列表样式。


3️⃣ ListView + ListTile 示例

ListView( children: [ ListTile(title: Text('设置')), ListTile(title: Text('账号')), ListTile(title: Text('关于')), ], )

五、ListView.builder:真正的实战重点(非常重要)

1️⃣ 为什么需要 builder?

当数据很多时:

❌ children 一次性创建所有 Widget
✅ builder 按需创建(性能更好)


2️⃣ 基本写法

ListView.builder( itemCount: 20, itemBuilder: (context, index) { return ListTile( title: Text('第 $index 项'), ); }, )

📌 记住一句话:

builder 是“用一个模板,生成很多项”


3️⃣ itemBuilder 参数说明

(BuildContext context, int index)
  • context:当前列表项的上下文
  • index:当前项的下标(从 0 开始)

六、使用数据列表生成 UI(真实开发)

final List<String> items = ['苹果', '香蕉', '橘子']; ListView.builder( itemCount: items.length, itemBuilder: (context, index) { return ListTile( title: Text(items[index]), ); }, )

📌 这是数据驱动 UI 的第一步


七、列表项点击(非常常见)

ListView.builder( itemCount: items.length, itemBuilder: (context, index) { return InkWell( onTap: () { print('点击了 ${items[index]}'); }, child: ListTile( title: Text(items[index]), ), ); }, )

八、ListView 中的分割线

1️⃣ Divider

Divider()

2️⃣ ListView.separated(推荐)

ListView.separated( itemCount: items.length, itemBuilder: (context, index) { return ListTile( title: Text(items[index]), ); }, separatorBuilder: (context, index) { return Divider(); }, )

📌分割线逻辑更清晰


九、ListView 常见错误与解决方案

❌ 错误 1:ListView 放在 Column 中报错

Column( children: [ ListView(...), ], )

❗ 报错原因:

ListView 没有高度约束


✅ 正确写法:Expanded

Column( children: [ Expanded( child: ListView(...), ), ], )

❌ 错误 2:嵌套滚动冲突

初学阶段建议:

一个页面只用一个 ListView


十、一个完整“真实页面”示例

class ListDemoPage extends StatelessWidget { final List<String> items = [ '个人信息', '账号设置', '隐私', '关于我们', ]; @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar(title: Text('设置')), body: ListView.separated( itemCount: items.length, itemBuilder: (context, index) { return ListTile( title: Text(items[index]), trailing: Icon(Icons.arrow_forward_ios, size: 16), onTap: () { print(items[index]); }, ); }, separatorBuilder: (_, __) => Divider(), ), ); } }

十一、新手常见误区总结

❌ 不会用 builder
❌ children 写死大量数据
❌ ListView 嵌套 Column 不加 Expanded
❌ 列表项布局混乱


十二、这一篇你真正学会了什么?

你已经掌握了:

  • ListView 的作用
  • ListView.builder 的核心思想
  • 数据驱动列表 UI
  • 点击列表项
  • 分割线的正确用法

你现在已经能写出:

真正的业务页面列表结构


十三、总结

本篇你学会了:

  • Flutter 中最重要的滚动组件
  • 列表的标准写法
  • 常见布局坑点

🔜 下一篇预告

《Flutter 零基础入门(二十九):ListView 进阶 —— 自定义列表项与复杂布局》

下一篇我们将学习:

  • 自定义列表项 UI
  • 列表项中嵌套 Row / Column
  • 卡片式列表
  • 更接近真实产品的布局

从下一篇开始:

你的 Flutter 页面将“无限接近真实商业 App” 🚀

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/30 10:52:12

消息队列使用场景:解耦、异步和削峰

消息队列作为现代分布式系统中的关键组件&#xff0c;其核心价值在于解耦服务、异步处理和削峰填谷。它并非一项炫技&#xff0c;而是解决特定工程问题的务实工具。理解其典型使用场景&#xff0c;能帮助我们判断何时该引入它&#xff0c;避免技术选型上的滥用或误用。 消息队列…

作者头像 李华
网站建设 2026/3/31 22:56:00

PaddlePaddle-v3.3 实战体验:从训练到部署,我踩过的坑与解决方案

PaddlePaddle-v3.3 作为国产领先深度学习框架&#xff0c;提供了丰富的新特性和优化工具。这篇文章我将结合实战经验&#xff0c;分享训练、部署以及踩过的坑和解决方案&#xff0c;帮助开发者快速上手。 一、PaddlePaddle-v3.3 新特性概览 PaddlePaddle-v3.3 相比之前版本的主…

作者头像 李华
网站建设 2026/4/1 2:55:13

C盘清理技巧分享:释放宝贵空间的方法

很多电脑C盘容易被占满&#xff0c;导致系统变慢甚至卡顿。今天分享一套高效清理C盘方案&#xff0c;帮你快速释放空间&#xff0c;同时保证安全。 一、准备工作 备份重要数据&#xff08;桌面、文档、下载等&#xff09;。确保C盘剩余空间 >1GB&#xff0c;避免清理过程中…

作者头像 李华
网站建设 2026/3/28 6:13:21

GEO 崛起,做 SEO 的还能继续做吗?真相在这里

最近这一两年&#xff0c;搞流量的圈子里人心惶惶。大家讨论最多的不是哪家外链便宜&#xff0c;也不是哪个关键词好做&#xff0c;而是 AI 搜索到底会不会把搜索引擎优化的饭碗给砸了。尤其是 GEO 这个词冒出来之后&#xff0c;很多人开始犯嘀咕&#xff0c;觉得辛辛苦苦码字、…

作者头像 李华
网站建设 2026/3/27 10:24:19

打造半导体行业培训新视野:3D动画助力固晶机应用解析

在半导体制造行业&#xff0c;固晶机作为一种关键设备&#xff0c;承担着将半导体芯片连接到封装基板上的重要任务。随着技术的发展和行业需求的变化&#xff0c;固晶机的应用也愈加广泛&#xff0c;涉及到LED制造、MEMS封装以及IC芯片的封装等多个领域。然而&#xff0c;由于固…

作者头像 李华