将数据添加到Flatlist(例如订阅)时,它向下滚动导致非常糟糕的UX。 关于如何解决这个问题的任何想法?
答案 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}
/>
这不是最好的解决方案,但现在可以解决我的问题