- 39
- 0
有这个一个使用场景,一个筛选页面,用户可以快速点击筛选条件,筛选条件一变,马上请求数据api,但是接口远在国外,可以理解为请求非常耗时,所以这个接口,经常会同时会有好几个请求在处理,然后页面数据会闪。
所以我想,对于同一个url,所有请求只留最新,旧的请求无论是成功还是padding状态,都放弃,网上查好多文章都只是说取消重复请求问题,跟我想要的有点区别,加上对前端不熟悉(本菜是后台,首次写前端项目),想好久未能想明白,故此劳烦各位大佬,为小弟指点一二,不胜感激!
现在已有拦截器如下(已删除无关代码)
import axios from 'axios'
const service = axios.create({
baseURL: 'a.com',
})
service.interceptors.request.use(config => {
return config
}, error => {
console.log(error)
Promise.reject(error)
})
service.interceptors.response.use(
response => response,
error => {
console.log('err' + error)
return Promise.reject(error)
})
export default service - 共 0 条
- 全部回答
-
ar烈酒℃灼言EL 普通会员 1楼
在axios中,你可以使用拦截器来拦截请求并处理请求。如果你想只保留某个接口的最新一次请求,你可以使用
axios.interceptors.request.use()方法来实现。这个方法接收一个回调函数,这个函数会在请求被发送之前被调用。你可以在这个回调函数中处理你的请求,然后在请求被发送时调用axios.interceptors.request.use()方法的回调函数。以下是一个例子:
javascript axios.interceptors.request.use(function (config) { // 在这里添加你的请求处理代码 // 如果你想只保留这个接口的最新一次请求,你可以这样做 config.response.data.lastRequest = new Date().getTime(); return config; }, function (error) { // 如果请求失败,你可以在这里添加你的错误处理代码 return Promise.reject(error); });在这个例子中,
config.response.data.lastRequest变量会保存每个接口的最新一次请求。你可以使用这个变量来决定应该保留哪些请求。注意:
axios.interceptors.request.use()方法只会拦截首次请求。如果你想处理后续的请求,你需要在每次请求时调用这个方法的回调函数。
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部

