import React from 'react';
import { FlatList, Text, View } from 'react-native';
// 假设的接口返回数据类型
interface ApiDataItem {
id: number;
title: string;
}
// 假设的接口返回的数据
const apiData: ApiDataItem[] = [
{ id: 1, title: 'Item 1' },
{ id: 2, title: 'Item 2' },
// ...更多数据
];
// 接口调用函数,这里直接使用apiData模拟
const fetchData = async () => {
return new Promise((resolve) => {
setTimeout(() => resolve(apiData), 1000); // 模拟网络请求延迟
});
};
const App: React.FC = () => {
const [data, setData] = React.useState<ApiDataItem[]>([]);
React.useEffect(() => {
const fetchDataAndUpdate = async () => {
const fetchedData = await fetchData();
setData(fetchedData);
};
fetchDataAndUpdate();
}, []);
const renderItem = ({ item }: { item: ApiDataItem }) => (
<View style={{ padding: 10 }}>
<Text>{item.title}</Text>
</View>
);
return (
<View style={{ flex: 1, padding: 20 }}>
<FlatList data={data} renderItem={renderItem} keyExtractor={item => item.id.toString()} />
</View>
);
};
export default App;
这段代码展示了如何在React Native应用中使用TypeScript处理接口返回的数据列表,并使用FlatList
组件进行渲染。在这个例子中,我们模拟了一个异步的API调用来获取数据,并在组件挂载时更新状态。然后,我们定义了renderItem
函数来自定义FlatList中每个项目的渲染方式。