博客
关于我
Flutter——ListView源码分析之child-view的构建
阅读量:356 次
发布时间:2019-03-04

本文共 1206 字,大约阅读时间需要 4 分钟。

ListView.builder 构造流程分析

在Flutter中,ListView.builder 是一个强大的工具,用于动态生成列表项。以下是其构造流程的详细分析:

1. ListView.builder 结构

ListView.builder 是一个构造函数,主要参数包括:

  • itemCount:指定列表的项数。
  • itemBuilder:一个IndexedWidgetBuilder,用于生成每个列表项。

它内部使用 SliverList 来管理这些项,并通过 SliverChildBuilderDelegate 来处理 itemBuilder。

2. SliverList 与 SliverChildBuilderDelegate

SliverList 是一个 Sliver widget,用于管理多个孩子 widget。它通过 SliverChildBuilderDelegate 来处理 itemBuilder 的调用。

  • SliverChildBuilderDelegate 接收 itemBuilder 和 itemCount,用于生成和管理列表项。
  • 每次调用 itemBuilder.build 时,会生成一个新的 widget。

3. 构建过程概述

  • 调用 buildChildLayout: ListView.builder 调用 buildChildLayout 方法,返回一个 SliverList。
  • SliverList 构造: SliverList 接收 childrenDelegate(由 SliverChildBuilderDelegate 实现),并生成多个项。
  • Scrollable widget 包裹: SliverList 被 Scrollable widget 包裹,支持滚动交互。
  • Viewport widget: Scrollable widget 内部使用 Viewport widget 管理视窗,构造最终的滚动列表。
  • 4. performRebuild 方法

    • performRebuild 方法由 SliverMultiBoxAdaptorElement 调用,用于触发 widget 的重建。
    • 它会调用 widget 的 build 方法,生成新的 widget。

    5. 列表项生成

    • 每次生成项时,itemBuilder 的 build 方法会被调用,传入当前 BuildContext 和索引。
    • 生成的 widget 会被添加到列表中,由 SliverList 管理。

    6. 总结

    ListView.builder 通过 SliverList 和 SliverChildBuilderDelegate 高效地管理列表项构建。其背后的机制涉及多个 Flutter widget,确保列表能够流畅滚动和高效绘制。理解这些内部机制有助于优化列表性能和用户体验。

    转载地址:http://tqnr.baihongyu.com/

    你可能感兴趣的文章
    php怎么将对象变成数组,php怎么将对象转换成数组
    查看>>
    RabbitMQ - 消息堆积问题的最佳解决方案?惰性队列
    查看>>
    php怎样比较两数大小,jquery如何判断两个数值的大小
    查看>>
    PHP性能监控 - 开启xhprof(一)
    查看>>
    PHP性能监控 - 怎么看xhprof报告(二)
    查看>>
    php截取字符串代码,PHP字符串截取_php
    查看>>
    php截取字符串,无乱码
    查看>>
    php手冊,php手冊之變量范圍
    查看>>
    PHP手机号码归属地查询API接口
    查看>>
    PHP执行耗时脚本实时输出内容
    查看>>
    PHP扩展安装
    查看>>
    PHP扩展数据库连接参数说明详解
    查看>>
    php把get参数放入数组_php怎么将数组转为url参数?
    查看>>
    PHP投票小程序
    查看>>
    php拆分数组不改变key值
    查看>>
    php接口返回数据 用echo 还是return?
    查看>>
    php接口返回状态,大家一般怎么规范接口返回内容
    查看>>
    php接收formdata上传的多个文件,使用formData()上传多个文件
    查看>>
    PHP操作csv文件导入+导出
    查看>>
    php操作mysql用select_php如何操作mysql获取select 结果
    查看>>