1

我正在尝试滚动到 flatlist 上的特定索引。我正在使用它的水平属性。我正在尝试使用 ref 滚动到特定索引。但我得到了错误。

scrollToIndex should be used in conjunction with getItemLayout or onScrollToIndexFailed, otherwise there is no way to know the location of offscreen indices or handle failures.

这是我的 Flatlist 代码:

<FlatList
     ref={flatRef}
     showsHorizontalScrollIndicator={false}
     horizontal
     data={data}
     renderItem={renderCell}
   />

这是在特定索引上滚动的代码:

flatRef.current.scrollToIndex({
  animated: false,
  index: index,
  viewPosition: 0.5,
});
4

2 回答 2

1

试试这个添加 onScrollToIndexFailed 功能

<FlatList
  ref={fListRef}
  onScrollToIndexFailed={info => {
    const wait = new Promise(resolve => setTimeout(resolve, 700));
    wait.then(() => {
      fListRef.current?.scrollToIndex({ index: info.index, animated: true/false });
    });
  }}
/>

您也可以结帐 git repo :: https://github.com/facebook/react-native/issues/14198

于 2020-11-04T09:26:17.270 回答
1

按照这个:

平面列表 - ScrollToIndex 应与 getItemLayout 或 onScrollToIndexFailed 一起使用

如上述问题中所述添加 onScrollToIndexFailed 道具

于 2020-11-04T09:18:35.233 回答