news 2026/6/15 13:10:22

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/6/11 8:05:37

从知识图谱到 GraphRAG:探索属性图的构建和复杂的数据检索实践

本文将探索属性图及其在提升数据表示和检索中的作用&#xff0c;同时借鉴 Ravi Theja&#xff08;LlamaIndex AI 工程师和布道师&#xff09;关于属性图的系列内容。通过这篇文章&#xff0c;我们将对如何使用 LlamaIndex 实现 GraphRAG 有一个清晰的理解&#xff0c;并附上一份…

作者头像 李华
网站建设 2026/6/13 10:33:32

appendChild返回值解析,节点操作技巧总结

在JavaScript DOM操作中&#xff0c;appendChild()是一个基础且重要的方法。开发者经常使用它来向页面动态添加元素&#xff0c;但关于其返回值&#xff0c;许多人在实际编码中存在模糊认识。本文将具体阐述appendChild()返回什么&#xff0c;以及理解这一返回值在实际项目中的…

作者头像 李华
网站建设 2026/6/3 6:16:52

零基础PHP从零到一实现上一页和下一页的庖丁解牛

实现上一页和下一页&#xff0c;不是简单地用 LIMIT offset, size&#xff0c;而是通过 游标分页&#xff08;Cursor-based Pagination&#xff09; 实现高性能、可扩展的分页。 一、核心原理&#xff1a;为什么不用 OFFSET&#xff1f; ▶ 1. OFFSET 的致命缺陷 -- 跳过 100…

作者头像 李华
网站建设 2026/6/9 16:34:57

终极预测:2030年,AI将自动编写测试用例?

——软件测试从业者的专业视角 引言&#xff1a;AI重塑测试领域的必然趋势 随着人工智能技术的飞速发展&#xff0c;软件测试行业正经历前所未有的变革。到2030年&#xff0c;AI不仅将辅助测试活动&#xff0c;更可能主导核心流程&#xff0c;其中测试用例的自动编写成为关键…

作者头像 李华
网站建设 2026/6/5 22:28:43

‌AI生成测试用例的“可执行性”难题:它写的你能跑吗?

AI生成的测试用例&#xff0c;平均可执行率不足60%‌ 根据信通院2026年初发布的《AI在软件测试中的规模化应用报告》&#xff0c;当前70%的中大型企业已部署AI生成测试用例工具&#xff0c;但‌实际可成功执行、无需人工修正的用例比例仅为54%-59%‌。这意味着每100条AI生成的…

作者头像 李华