javascript-在axios超时后获得通知
作者:互联网
我使用axios进行了API调用.超时设置为2500毫秒.我所不希望的是axios在超时后返回一个值,因此我可以通知用户由于某些服务器或网络错误而中止该请求.
我如何初始化超时
const instance = axios.create();
instance.defaults.timeout = 2500;
以下是超时后应返回值的函数
_post(url, body, token) {
return new Promise((resolve, reject) => {
instance
.post(url, body, {headers: {
'Accept': 'application/json',
'Content-Type': 'application/json'
}})
.then(data => {
resolve(data);
})
.catch(error => {
reject(error);
});
});
}
谢谢!
解决方法:
Axios错误由code
property标识.
如果超时,则为ECONNABORTED
code.
上面的代码使用promise构造反模式.已经有了一个承诺,无需创建一个新的承诺:
_post(url, body, token) {
return instance
.post(url, body, {headers: {
'Accept': 'application/json',
'Content-Type': 'application/json'
}})
.catch(error => {
if (error.code === 'ECONNABORTED')
return 'timeout';
else
throw error;
});
}
标签:axios,typescript,ecmascript-6,es6-promise,javascript 来源: https://codeday.me/bug/20191109/2010665.html