长列表的处理
标准的 ListView
构造函数适用于短列表,对于具有大量列表项的长列表,需要用 ListView.builder
构造函数来创建。
与标准的 ListView
构造函数需要一次性创建所有列表项不同的是,
ListView.builder
构造函数只在列表项从屏幕外滑入屏幕时才去创建列表项。
1. 创建数据源
#首先,需要获取列表的数据源。例如,数据源可以是消息集、搜索结果集或者商店商品集。大部分情况下,这些数据来自于网络请求或者数据库获取。
在下面的例子,使用 List.generate
构造函数生成包含 10,000 个字符串的集合。
List<String>.generate(10000, (i) => 'Item $i'),
2. 将数据源渲染成组件
#为了将字符串集合展示出来,需要通过 ListView.builder
把集合中的每个字符串都渲染成组件。
在下面的例子中,将会把每个字符串用单行列表项显示在列表中。
ListView.builder(
itemCount: items.length,
prototypeItem: ListTile(
title: Text(items.first),
),
itemBuilder: (context, index) {
return ListTile(
title: Text(items[index]),
);
},
)
交互式样例
#import 'package:flutter/material.dart';
void main() {
runApp(
MyApp(
items: List<String>.generate(10000, (i) => 'Item $i'),
),
);
}
class MyApp extends StatelessWidget {
final List<String> items;
const MyApp({super.key, required this.items});
@override
Widget build(BuildContext context) {
const title = 'Long List';
return MaterialApp(
title: title,
home: Scaffold(
appBar: AppBar(
title: const Text(title),
),
body: ListView.builder(
itemCount: items.length,
prototypeItem: ListTile(
title: Text(items.first),
),
itemBuilder: (context, index) {
return ListTile(
title: Text(items[index]),
);
},
),
),
);
}
}
Children's extent
#To specify each item's extent, you can use either prototypeItem
, itemExtent
,
or itemExtentBuilder
.
Specifying either is more efficient than letting the children determine their own extent because the scrolling machinery can make use of the foreknowledge of the children's extent to save work, for example when the scroll position changes drastically.
Use prototypeItem
or itemExtent
if your list has items of fixed size.
Use itemExtentBuilder
if your list has items of different sizes.
除非另有说明,本文档之所提及适用于 Flutter 的最新稳定版本,本页面最后更新时间: 2024-07-03。 查看文档源码 或者 为本页面内容提出建议。