为了账号安全,请及时绑定邮箱和手机立即绑定

react 16.8.6 前端请求,用useEffect调用接口,但是这样接口会被不停的调用,那么代码该怎么写?跪求!

react 16.8.6 前端请求,用useEffect调用接口,但是这样接口会被不停的调用,那么代码该怎么写?跪求!

慕妹3242003 2019-07-14 22:09:44
react16.8.6前端请求,打开页面就要调用接口,获取数据,于是用useEffect调用接口,但是这样接口会被不停的调用,那么代码该怎么写?useEffect(()=>{axios.get('/getYearMonth').then(res=>{console.log('getYearMonth',res);setValues(oldValues=>({...oldValues,fileList:res.data.msg}));})},[values]);
查看完整描述

2 回答

?
宝慕林4294392

TA贡献2021条经验 获得超8个赞

//页面进来只调用一次
useEffect(()=>{
axios.get('/getYearMonth').then(res=>{
console.log('getYearMonth',res);
setValues(oldValues=>({
...oldValues,
fileList:res.data.msg
}));
})
},[]);
                            
查看完整回答
反对 回复 2019-07-14
?
绝地无双

TA贡献1946条经验 获得超4个赞

这么写:
useEffect(()=>{
axios.get('/getYearMonth').then(res=>{
console.log('getYearMonth',res);
setValues(oldValues=>({
...oldValues,
fileList:res.data.msg
}));
})
},[]);
你现在的写法是每当values有变化时都会触发一次,刚好里面请求返回时将values给重新进行了赋值,导致会一直循环触发事件
                            
查看完整回答
反对 回复 2019-07-14
  • 2 回答
  • 0 关注
  • 559 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号