Flutter 中,ListView 中需要放置 ListView 需要怎么处理才高效?

问题及场景

ListView 是 Flutter 开发者第一个学习到的 Widget,因为它可以滑动。一切都会运行得很好,直到 ListView 中的 Item 本身也是一个 ListView。你可能会看到 Flutter 建议你将内部的 ListView 的ShrinkWrap 属性设置为 True。虽然错误消除了,但是威胁还在。因为 ShrinkWrap 属性会将 ListView 一次性全部填充,算出所有高度,如果内部 ListView 的数据量比较大,那将产生性能问题,会有很大的风险掉帧、jank 和 stutters。

假设你遇到下面这样的场景

dart 复制代码
final outerListChildren = <ListView>[
	ListView(children: <Wdiget>[...]),
	...
];

return ListView.Builder(
	itemCount: outerListChildren.length,
	itemBuilder: (context, index) {
		return outerListChildren[index]
	}
)

然后我们按照 Flutter 的提示,将内部的 ListView 加上 shrinkWrap 和 physics 属性如下

dart 复制代码
final outerListChildren = <ListView>[
	ListView(
		shrinkWrap: true,
		physics: const NeverScrollableScrollPhysics(),
		children: <Wdiget>[...]
	),
	...
];

return ListView.Builder(
	itemCount: outerListChildren.length,
	itemBuilder: (context, index) {
		return outerListChildren[index]
	}
)

解决方法:

1、首先,将最外层的 ListView 改为 CustomScrollView

dart 复制代码
return CustomScrollView(
		children: outerListChildren
	}
)

2、然后我们将外部的 ListView 列表改为 SliverList 列表

dart 复制代码
final outerListChildren = <SliverList>[];
return CustomScrollView(
		children: outerListChildren
	}
)

3、所有 SliverList 添加 delegate,并使用 SliverChildBuilderDelegate 作为 value,_myWidgets 是之前的 inner ListView 需要显示的内容

dart 复制代码
final outerListChildren = <SliverList>[
	SliverList(
		delegate: SliverChildBuilderDelegate(
			childCount: _myWidgets.length,
			(context, index) => _myWidgets[index]
		)
	)
];
return CustomScrollView(
		children: outerListChildren
	}
)

至此,大功告成

相关推荐
G_dou_1 小时前
Flutter三方库适配OpenHarmony【unit_converter】单位转换器项目完整实战
flutter·harmonyos
夜焱辰3 小时前
浏览器端 Agent 的文件版本管理:不用 Git,基于 OPFS + SQLite 自己造了一个
前端·人工智能
梦想的颜色3 小时前
TypeScript 完全指南(下):从类型体操到生产级配置
前端·javascript·typescript
Hi~晴天大圣5 小时前
npm使用介绍
前端·npm·node.js
888CC++6 小时前
如何在 C 语言中进行程序调试?
前端·javascript·算法
喵个咪6 小时前
基于 Taro 的 Headless CMS 多端前端架构:技术解析与二次开发导引
前端·react.js·taro
狂炫冰美式6 小时前
你还在古法PPT吗,试试HTML呢?免费编辑导出工具给 xdm 放这了
前端·后端·github
万少7 小时前
未来组织的分水岭不是员工数量,而是人才密度
前端·后端·面试
任磊abc7 小时前
nextjs16配置eslint+prettier
前端·eslint·nextjs·prettier
x***r1517 小时前
Another-Redis-Desktop-Manager.1.3.7安装步骤详解(附Redis可视化连接与Key管理教程)
前端·bootstrap·html