添加新项目时,防止Flatlist滚动

时间:2017-04-25 13:03:31

标签: react-native

将数据添加到Flatlist(例如订阅)时,它向下滚动导致非常糟糕的UX。 关于如何解决这个问题的任何想法?

1 个答案:

答案 0 :(得分:3)

实际上,我认为必须在本机级别处理,但尚未处理, 我通过保存滚动偏移来解决我的问题,并在重新加载数据之后再次设置它:

reloadData(flatListData){

   this.setState({
       flatListData: flatListData
   });

   requestAnimationFrame(() => {
         this.flatList.scrollToOffset({
                       animated: false,
                       offset: this.flatListLastOffset
             });
   });
}

...

<FlatList
     data={this.state.flatListData}
     ref={ref => this.flatList = ref}
     onScroll={(event: Object) => {
           this.flatListLastOffset = event.nativeEvent.contentOffset.y;
           }}
     horizontal={false}
     scrollEventThrottle={16}
 />

这不是最好的解决方案,但现在可以解决我的问题