为什么每当我使用React Navigation,usafeft和Axios导航到详细信息屏幕时,它显示了以前的数据
我正在尝试使用Expo构建电影详细信息React Antive App,并且每当我试图从家中导航到详细信息页面时,每当我在电影详细信息页面上显示以前的数据时。如何解决这个问题。 我正在使用React Navigation在屏幕之间导航,并且我也使用Axios获取来自API的数据。 我不明白,为什么每次显示先前的数据时。
视频 - https://www.youtube.com/shorts/0jgl2spyujw
- https://i.sstatic.net/0qle1.png
const DetailsScreen = ({ route, navigation }) => {
const [apis, setApis] = useState([]);
const URL = "https://demoapi.com" + route.params.categoryWithId;
useEffect(() => {
console.log("Top ==>" + URL);
async function getAllData() {
try {
const apis = await axios.get(URL);
setApis(apis.data);
} catch (error) {
console.log(error);
}
}
getAllData();
}, []);
if (!apis.length) return null;
console.log("details ==> " + JSON.stringify(apis));
return (
<>
<ImageBackground source={{ uri: apis[0].image }} resizeMode="cover" style={styles.backgroundImage} >
<Wrapper>
{/* PlatformLogo */}
<ImageBackground
resizeMode="contain"
source={{
uri: "https://pngimg.com/uploads/netflix/netflix_PNG32.png",
}}
style={styles.platformLogo}
/>
<Title>{apis[0].title}</Title>
{/* <Text>{verticlebanner}</Text> */}
<SubTitle>{apis[0].date}</SubTitle>
<PlayIcon
style={{
backgroundColor: "white",
borderRadius: 50,
}}
/>
</Wrapper>
</ImageBackground>
<StatusBar hidden />
</>
);
};
屏幕显示“ Dr. Strange”,然后我单击“壁架”,然后显示“ Minions”的数据等... 为什么它每次都显示以前的数据
I am trying to build a movie details react native app with expo and whenever I'm trying to navigate from home to details page, every time it shows me previous data on movie details page. How to solve this issue.
I am using react navigation to navigate between screens and also I'm using axios to get data from and api.
I didn't understand, why every time it shows previous data.
Preview in video- https://www.youtube.com/shorts/0JgL2SPyujw
DetailsScreen.js- https://i.sstatic.net/0qLE1.png
const DetailsScreen = ({ route, navigation }) => {
const [apis, setApis] = useState([]);
const URL = "https://demoapi.com" + route.params.categoryWithId;
useEffect(() => {
console.log("Top ==>" + URL);
async function getAllData() {
try {
const apis = await axios.get(URL);
setApis(apis.data);
} catch (error) {
console.log(error);
}
}
getAllData();
}, []);
if (!apis.length) return null;
console.log("details ==> " + JSON.stringify(apis));
return (
<>
<ImageBackground source={{ uri: apis[0].image }} resizeMode="cover" style={styles.backgroundImage} >
<Wrapper>
{/* PlatformLogo */}
<ImageBackground
resizeMode="contain"
source={{
uri: "https://pngimg.com/uploads/netflix/netflix_PNG32.png",
}}
style={styles.platformLogo}
/>
<Title>{apis[0].title}</Title>
{/* <Text>{verticlebanner}</Text> */}
<SubTitle>{apis[0].date}</SubTitle>
<PlayIcon
style={{
backgroundColor: "white",
borderRadius: 50,
}}
/>
</Wrapper>
</ImageBackground>
<StatusBar hidden />
</>
);
};
when I click on "minions" then details screens shows "dr. strange" and I click on "the ledge" then it shows data of "minions" and so on...
why it shows previous data every times
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
根据您的代码,仅需要lodader或isloading状态以进行API调用和状态更新,如下所示,代码对我来说很好。
As per your code it only required lodader or isLoading state for api call and state update as shown in below code it works fine for me.