跳到主要内容
版本:0.81

FlatList

一个用于渲染基本扁平列表的高性能接口,支持以下最实用的功能:

  • 完全跨平台。
  • 可选的水平模式。
  • 可配置的可见性回调。
  • 支持头部。
  • 支持底部。
  • 支持分隔符。
  • 下拉刷新。
  • 滚动加载。
  • 支持 ScrollToIndex。
  • 支持多列。

如果你需要分区支持,请使用 <SectionList>

示例

要渲染多列,请使用 numColumns 属性。使用此方法而不是 flexWrap 布局可以防止与项高度逻辑发生冲突。

下方是一个更复杂的、可选择的示例。

  • 通过传递 extraData={selectedId}FlatList,我们确保当状态变化时 FlatList 本身会重新渲染。如果不设置此属性,FlatList 将不知道它需要重新渲染任何项,因为它是一个 PureComponent 并且属性比较不会显示任何变化。
  • keyExtractor 告诉列表使用 id 作为 react 键,而不是默认的 key 属性。

这是 <VirtualizedList> 的便捷包装器,因此继承了其属性(以及 <ScrollView> 的属性),除非此处明确列出,同时具有以下注意事项:

  • 当内容滚动出渲染窗口时,内部状态不会保留。确保所有数据都捕获在项数据或外部存储中,如 Flux、Redux 或 Relay。
  • 这是一个 PureComponent,这意味着如果 props 保持浅相等,它将不会重新渲染。确保你的 renderItem 函数依赖的所有内容都作为属性传递(例如 extraData),并且在更新后不 ===,否则你的 UI 可能不会随变化而更新。这包括 data 属性和父组件状态。
  • 为了限制内存并实现平滑滚动,内容在屏幕外异步渲染。这意味着有可能滚动速度快于填充率,并暂时看到空白内容。这是一个可以根据每个应用程序的需求进行调整的权衡,我们正在幕后改进它。
  • 默认情况下,列表会查找每个项上的 key 属性并将其用作 React 键。或者,你可以提供自定义的 keyExtractor 属性。

参考

属性

VirtualizedList 属性

继承 VirtualizedList 属性


必需
renderItem

tsx
renderItem({
item: ItemT,
index: number,
separators: {
highlight: () => void;
unhighlight: () => void;
updateProps: (select: 'leading' | 'trailing', newProps: any) => void;
}
}): JSX.Element;

data 中获取一个项并将其渲染到列表中。

提供额外的元数据,如 index(如果你需要的话),以及一个更通用的 separators.updateProps 函数,它允许你设置任何想要更改的属性,以改变前导分隔符或尾随分隔符的渲染,以防更常见的 highlightunhighlight(它们设置 highlighted: boolean 属性)不足以满足你的用例。

类型
function
  • item (Object): 正在渲染的来自 data 的项。
  • index (number): 此项在 data 数组中对应的索引。
  • separators (Object)
    • highlight (Function)
    • unhighlight (Function)
    • updateProps (Function)
      • select (enum('leading', 'trailing'))
      • newProps (Object)

使用示例:

tsx
<FlatList
ItemSeparatorComponent={
Platform.OS !== 'android' &&
(({highlighted}) => (
<View
style={[style.separator, highlighted && {marginLeft: 0}]}
/>
))
}
data={[{title: 'Title Text', key: 'item1'}]}
renderItem={({item, index, separators}) => (
<TouchableHighlight
key={item.key}
onPress={() => this._onPress(item)}
onShowUnderlay={separators.highlight}
onHideUnderlay={separators.unhighlight}>
<View style={{backgroundColor: 'white'}}>
<Text>{item.title}</Text>
</View>
</TouchableHighlight>
)}
/>

必需
data

一个要渲染的项的数组(或类数组列表)。可以通过直接针对 VirtualizedList 来使用其他数据类型。

类型
ArrayLike

ItemSeparatorComponent

渲染在每项之间,但不在顶部或底部。默认情况下,提供 highlightedleadingItem 属性。renderItem 提供 separators.highlight/unhighlight 将更新 highlighted 属性,但你也可以使用 separators.updateProps 添加自定义属性。可以是一个 React 组件(例如 SomeComponent),或一个 React 元素(例如 <SomeComponent />)。

类型
component, function, element

ListEmptyComponent

当列表为空时渲染。可以是一个 React 组件(例如 SomeComponent),或一个 React 元素(例如 <SomeComponent />)。

类型
component, element

ListFooterComponent

渲染在所有项的底部。可以是一个 React 组件(例如 SomeComponent),或一个 React 元素(例如 <SomeComponent />)。

类型
component, element

ListFooterComponentStyle

ListFooterComponent 内部 View 的样式。


ListHeaderComponent

渲染在所有项的顶部。可以是一个 React 组件(例如 SomeComponent),或一个 React 元素(例如 <SomeComponent />)。

类型
component, element

ListHeaderComponentStyle

ListHeaderComponent 内部 View 的样式。


columnWrapperStyle

numColumns > 1 时,为生成的多项目行提供的可选自定义样式。


extraData

一个标记属性,用于告诉列表重新渲染(因为它实现了 PureComponent)。如果你的任何 renderItem、Header、Footer 等函数依赖于 data 属性之外的任何内容,请将其放在这里并将其视为不可变的。

类型
any

getItemLayout

tsx
(data, index) => {length: number, offset: number, index: number}

getItemLayout 是一个可选的优化,如果你提前知道项的大小(高度或宽度),它可以跳过动态内容的测量。如果你有固定大小的项,getItemLayout 非常高效,例如:

tsx
  getItemLayout={(data, index) => (
{length: ITEM_HEIGHT, offset: ITEM_HEIGHT * index, index}
)}

添加 getItemLayout 可以极大地提升几百项列表的性能。如果你指定了 ItemSeparatorComponent,请记住在偏移计算中包含分隔符长度(高度或宽度)。

类型
function

horizontal

如果为 true,则水平相邻渲染项,而不是垂直堆叠。

类型
boolean

initialNumToRender

初始批次中要渲染多少项。这应该足以填充屏幕,但不要太多。注意,作为窗口化渲染的一部分,这些项永远不会被卸载,以提高滚动到顶部操作的感知性能。

类型默认值
number10

initialScrollIndex

不从第一个项的顶部开始,而是从 initialScrollIndex 开始。这会禁用“滚动到顶部”优化(该优化保持前 initialNumToRender 项始终渲染),并立即渲染从此初始索引开始的项。需要实现 getItemLayout

类型
number

inverted

反转滚动方向。使用 -1 的缩放变换。

类型
boolean

keyExtractor

tsx
(item: ItemT, index: number) => string;

用于提取指定索引处给定项的唯一键。键用于缓存并作为 react 键来跟踪项重新排序。默认提取器检查 item.key,然后 item.id,然后像 React 一样回退到使用索引。

类型
function

numColumns

多列只能在 horizontal={false} 时渲染,并且会像 flexWrap 布局一样 zig-zag 排列。项都应该具有相同的高度 - 不支持砌体布局。

类型
number

onRefresh

tsx
() => void;

如果提供,将为“下拉刷新”功能添加标准的 RefreshControl。确保也正确设置 refreshing 属性。

类型
function

onViewableItemsChanged

当行的可见性发生变化时调用,由 viewabilityConfig 属性定义。

类型
(callback: {changed: ViewToken[], viewableItems: ViewToken[]} => void;

progressViewOffset

当需要偏移量以使加载指示器正确显示时设置此项。

类型
number

refreshing

当等待刷新带来的新数据时设置为 true。

类型
boolean

removeClippedSubviews

注意

使用此属性在某些情况下可能导致 bug(内容缺失)- 使用风险自负。

true 时,离屏子视图在离屏时从其原生备份父视图中移除。这可以提高大列表的滚动性能。在 Android 上,默认值为 true

类型
boolean

viewabilityConfig

参见 ViewabilityHelper.js 获取 flow 类型和进一步文档。

类型
ViewabilityConfig

viewabilityConfig 接受一个 ViewabilityConfig 类型的对象,包含以下属性

属性类型
minimumViewTimenumber
viewAreaCoveragePercentThresholdnumber
itemVisiblePercentThresholdnumber
waitForInteractionboolean

至少需要 viewAreaCoveragePercentThresholditemVisiblePercentThreshold 中的一个。这需要在 constructor 中完成,以避免以下错误 (参考):

  Error: Changing viewabilityConfig on the fly is not supported
tsx
constructor (props) {
super(props)

this.viewabilityConfig = {
waitForInteraction: true,
viewAreaCoveragePercentThreshold: 95
}
}
tsx
<FlatList
viewabilityConfig={this.viewabilityConfig}
...

minimumViewTime

项必须物理可见的最小时间量(毫秒),之后才会触发可见性回调。较高的数字意味着不停止地滚动内容不会将内容标记为可见。

viewAreaCoveragePercentThreshold

视口必须被覆盖的百分比,以便部分遮挡的项被视为“可见”,0-100。完全可见的项始终被视为可见。值为 0 意味着视口中的单个像素使项可见,值为 100 意味着项必须完全可见或覆盖整个视口才算作可见。

itemVisiblePercentThreshold

类似于 viewAreaCoveragePercentThreshold,但考虑的是项可见的百分比,而不是它覆盖的可见区域的比例。

waitForInteraction

在用户滚动或渲染后调用 recordInteraction 之前,没有任何内容被视为可见。


viewabilityConfigCallbackPairs

ViewabilityConfig/onViewableItemsChanged 对的列表。当对应的 ViewabilityConfig 条件满足时,将调用特定的 onViewableItemsChanged。参见 ViewabilityHelper.js 获取 flow 类型和进一步文档。

类型
array of ViewabilityConfigCallbackPair

方法

flashScrollIndicators()

tsx
flashScrollIndicators();

短暂显示滚动指示器。


getNativeScrollRef()

tsx
getNativeScrollRef(): React.ElementRef<typeof ScrollViewComponent>;

提供对底层滚动组件的引用


getScrollResponder()

tsx
getScrollResponder(): ScrollResponderMixin;

提供对底层滚动响应器的句柄。


getScrollableNode()

tsx
getScrollableNode(): any;

提供对底层滚动节点的句柄。

scrollToEnd()

tsx
scrollToEnd(params?: {animated?: boolean});

滚动到内容末尾。如果没有 getItemLayout 属性,可能会卡顿。

参数:

名称类型
paramsobject

有效的 params 键包括:

  • 'animated' (boolean) - 列表在滚动时是否执行动画。默认为 true

scrollToIndex()

tsx
scrollToIndex: (params: {
index: number;
animated?: boolean;
viewOffset?: number;
viewPosition?: number;
});

滚动到指定索引的项,使其位于可见区域内,其中 viewPosition 0 将其放置在顶部,1 在底部,0.5 居中。

注意:如果不指定 getItemLayout 属性,无法滚动到渲染窗口之外的位置。

参数:

名称类型
params
必需
object

有效的 params 键包括:

  • 'animated' (boolean) - 列表在滚动时是否执行动画。默认为 true
  • 'index' (number) - 要滚动到的索引。必需。
  • 'viewOffset' (number) - 偏移最终目标位置的固定像素数。
  • 'viewPosition' (number) - 值 0 将索引指定的项放置在顶部,1 在底部,0.5 居中。

scrollToItem()

tsx
scrollToItem(params: {
animated?: ?boolean,
item: Item,
viewPosition?: number,
});

需要线性扫描数据 - 如果可能,请使用 scrollToIndex 代替。

注意:如果不指定 getItemLayout 属性,无法滚动到渲染窗口之外的位置。

参数:

名称类型
params
必需
object

有效的 params 键包括:

  • 'animated' (boolean) - 列表在滚动时是否执行动画。默认为 true
  • 'item' (object) - 要滚动到的项。必需。
  • 'viewPosition' (number)

scrollToOffset()

tsx
scrollToOffset(params: {
offset: number;
animated?: boolean;
});

滚动到列表中特定的内容像素偏移量。

参数:

名称类型
params
必需
object

有效的 params 键包括:

  • 'offset' (number) - 要滚动到的偏移量。如果 horizontal 为 true,偏移量为 x 值,其他情况下偏移量为 y 值。必需。
  • 'animated' (boolean) - 列表在滚动时是否执行动画。默认为 true