我们的网站目前有一个过滤器功能,可以根据过滤的内容通过 axios 获取新数据。
问题是过滤器是实时完成的,通过 react 所做的每一次更改都会导致 axios 请求。
有没有办法在 axios 请求上设置超时,以便我只获取最后一个状态?
我们的网站目前有一个过滤器功能,可以根据过滤的内容通过 axios 获取新数据。
问题是过滤器是实时完成的,通过 react 所做的每一次更改都会导致 axios 请求。
有没有办法在 axios 请求上设置超时,以便我只获取最后一个状态?
我建议debounce
在这种情况下使用在指定的用户输入毫秒后触发 API 调用。
但以防万一您需要在axios调用期间添加超时,这可以像 -
instance.get('/longRequest', {
timeout: 5000
});
问题有两个部分。
第一部分是 debounce,并且是可以经常触发的事件侦听器的默认设置,尤其是当它们的调用成本高昂或可能导致不良影响时。HTTP 请求属于这一类。
第二部分是,如果 debounce 延迟小于 HTTP 请求持续时间(这对于虚拟每种情况都是如此),仍然会有竞争请求,响应会随着时间的推移导致状态变化,并且不一定是正确的顺序。
第一部分使用 debounce 函数来减少竞争请求的数量,第二部分使用 Axios取消 API在有新请求时取消未完成的请求,例如:
onChange = e => {
this.fetchData(e.target.value);
};
fetchData = debounce(query => {
if (this._fetchDataCancellation) {
this._fetchDataCancellation.cancel();
}
this._fetchDataCancellation = CancelToken.source();
axios.get(url, {
cancelToken: this._fetchDataCancellation.token
})
.then(({ data }) => {
this.setState({ data });
})
.catch(err => {
// request was cancelled, not a real error
if (axios.isCancel(err))
return;
console.error(err);
});
}, 200);
这是一个演示。
您还可以将axios.defaults
所有请求用作一般设置:
axios.defaults.timeout = 5000