import React from 'react';
import { FlatList } from 'react-native';
export default class InfiniteScrollExample extends React.Component {
constructor(props) {
super(props);
this.state = {
data: [],
pageIndex: 1,
isLoading: false,
isEnd: false,
};
}
fetchData = async () => {
if (this.state.isLoading || this.state.isEnd) return;
this.setState({ isLoading: true });
try {
const response = await fetch(
`https://api.example.com/data?page=${this.state.pageIndex}`
);
const newData = await response.json();
this.setState(prevState => ({
data: [...prevState.data, ...newData.data],
pageIndex: prevState.pageIndex + 1,
isLoading: false,
isEnd: newData.data.length === 0,
}));
} catch (error) {
console.error('Error fetching data: ', error);
this.setState({ isLoading: false });
}
};
componentDidMount() {
this.fetchData();
}
render() {
return (
<FlatList
data={this.state.data}
keyExtractor={item => item.id}
renderItem={({ item }) => (
// 渲染每个item的组件
)}
onEndReached={this.fetchData}
onEndReachedThreshold={0.01} // 当距离底部还有1%的距离时触发
ListFooterComponent={this.state.isLoading ? <LoadingComponent /> : null}
/>
);
}
}
// 加载组件的示例
const LoadingComponent = () => (
<View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}>
<ActivityIndicator size="large" color="#0000ff" />
</View>
);
这个简化的代码示例展示了如何在React Native应用中实现无限滚动列表。它使用了FlatList
组件,并通过分页从API获取数据。当用户接近列表底部时,它会自动加载更多数据,并且使用ActivityIndicator
显示加载状态。这是一个典型的React Native无限滚动视图的实现方式。