flutter长列表 ListView、GridView、SingleChildScrollView、CustomScrollView区别

组件名称 用途/适合场景 是否懒加载 支持列表结构 用法复杂度
SingleChildScrollView 适用于内容数量不大、不重复的页面(如表单、静态内容) ❌ 否 ❌ 否 ⭐⭐
ListView 适用于垂直方向的长列表,自动滚动;适合展示大量数据 ✅ 支持 ✅ 是 ⭐⭐
ListView.builder 优化版 ListView,适合超长动态列表,按需懒加载构建 ✅ 强烈推荐 ✅ 是 ⭐⭐⭐
GridView 适用于网格状布局,如图片列表 ✅ 支持 ✅ 是(网格) ⭐⭐⭐
CustomScrollView 高级滚动视图,组合多个滚动子元素(如 SliverAppBar + SliverList) ✅ 支持 ✅ 是(灵活 ⭐⭐⭐⭐
PageView 水平翻页,用于页面轮播、引导页、Tab 内容切换等 ✅ 每页懒加载 ❌ 否 ⭐⭐
Scrollable(低阶) 最底层滚动组件,通常不建议直接使用,除非自定义滚动行为 ❓ 取决于实现 ⭐⭐⭐⭐⭐

常见使用场景说明

  1. SingleChildScrollView
    适合非列表型的页面,比如表单、图文页面。

    SingleChildScrollView(
    child: Column(
    children: [...],
    ),
    )

  • 不支持懒加载
  • 所有子项一次性渲染
  • 不建议用于长列表,性能差
  1. ListView / ListView.builder
    适合列表型页面(如聊天记录、新闻列表、商品列表等)

    ListView(
    children: [
    Text('Item 1'),
    Text('Item 2'),
    ],
    )

    // 更推荐
    ListView.builder(
    itemCount: 1000,
    itemBuilder: (context, index) => Text('Item $index'),
    )

  • 支持滚动
  • 支持懒加载(builder 模式)
  • 更适合长内容
  1. GridView
    用于网格状内容(如相册、九宫格)

    GridView.count(
    crossAxisCount: 2,
    children: [...],
    )

  • 有滚动能力
  • 可用于横向或纵向
  • 可指定网格数量、间距
  1. CustomScrollView + Slivers
    用于构建更复杂滚动效果,比如顶部可折叠 AppBar + 列表内容

    CustomScrollView(
    slivers: [
    SliverAppBar(
    expandedHeight: 200,
    flexibleSpace: FlexibleSpaceBar(title: Text('标题')),
    pinned: true,
    ),
    SliverList(
    delegate: SliverChildBuilderDelegate(
    (context, index) => ListTile(title: Text('Item $index')),
    childCount: 50,
    ),
    ),
    ],
    )

  • 高度可定制,滚动联动效果
  • 用于复杂的 UI 页面(如首页、动态页)
  1. PageView

    PageView(
    children: [
    Container(color: Colors.red),
    Container(color: Colors.green),
    ],
    )

  • 适用于引导页、卡片轮播、Tab 页
  • 支持左右/上下滑动
  • 支持手势控制、自动翻页

总结建议

页面类型 推荐滚动组件
表单、静态信息页面 SingleChildScrollView
聊天、列表、动态加载页面 ListView.builder
图片网格、宫格商品 GridView
首页、复杂滑动结构页面 CustomScrollView
引导页、卡片轮播 PageView
相关推荐
大橙子额4 小时前
【解决报错】Cannot assign to read only property ‘exports‘ of object ‘#<Object>‘
前端·javascript·vue.js
一只大侠的侠4 小时前
【Harmonyos】Flutter开源鸿蒙跨平台训练营 Day 2 鸿蒙跨平台开发环境搭建与工程实践
flutter·开源·harmonyos
WooaiJava5 小时前
AI 智能助手项目面试技术要点总结(前端部分)
javascript·大模型·html5
微祎_5 小时前
Flutter for OpenHarmony:构建一个 Flutter 平衡球游戏,深入解析动画控制器、实时物理模拟与手势驱动交互
flutter·游戏·交互
爱喝白开水a5 小时前
前端AI自动化测试:brower-use调研让大模型帮你做网页交互与测试
前端·人工智能·大模型·prompt·交互·agent·rag
Never_Satisfied5 小时前
在JavaScript / HTML中,关于querySelectorAll方法
开发语言·javascript·html
董世昌415 小时前
深度解析ES6 Set与Map:相同点、核心差异及实战选型
前端·javascript·es6
WeiXiao_Hyy6 小时前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
ZH15455891316 小时前
Flutter for OpenHarmony Python学习助手实战:面向对象编程实战的实现
python·学习·flutter
吃杠碰小鸡6 小时前
高中数学-数列-导数证明
前端·数学·算法