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

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

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

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

2 回答

?
慕丝7291255

TA贡献1859条经验 获得超6个赞

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

TA贡献1802条经验 获得超6个赞

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

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信