Vue 结合 Axios 接口超时统一处理

2019-12-05 17:01:36

参考地址 Vue 结合 Axios 接口超时统一处理

引语:当网路慢的时候。又或者公司服务器不在内地的时候,接口数据请求不回来超时报错的情况相信大家肯定遇到过的,这里我把我公司项目请求超时的处理方法分享下,希望看过后有帮助。

axios基本用法就不多说了,详情直戳 : https://www.kancloud.cn/yunye/axios/234845

主要是思路: 对 axios 请求拦截器下功夫

解决方案一:(缺点:只重新请求1次,如果再超时的话,它就停止了,不会再请求) 后台只允许你重新发起一次请求(不能给服务器增压、浪费带宽无限请求,)下的情况推荐;

看了看axios的源代码,超时后, 会在拦截器那里 axios.interceptors.response 捕抓到错误信息, 且 error.code = "ECONNABORTED"

复制代码

 // 请求超时request.ontimeout = function handleTimeout() {  reject(createError('timeout of ' + config.timeout + 'ms exceeded', config, 'ECONNABORTED', request));  // 取消请求
  request = null;
};

复制代码

全局超时处理方案:

复制代码

// 请求拦截器axios.interceptors.response.use(function(response){    // 请求成功处理回调}, function(error){    // 请求失败、错误处理回调
    var originalRequest = error.config; 
    if(error.code == 'ECONNABORTED' && error.message.indexOf('timeout')!=-1 && !originalRequest._retry){       originalRequest._retry = true
       return axios.request(originalRequest);
    }
});

复制代码

解决方法二:推荐

复制代码

//在main.js设置全局的请求次数,请求的间隙axios.defaults.retry = 4;axios.defaults.retryDelay = 1000;axios.interceptors.response.use(undefined, function axiosRetryInterceptor(err) { var config = err.config; // 如果config不存在或未设置重试选项,请拒绝
 if(!config || !config.retry) return Promise.reject(err); // 设置变量跟踪重试次数
 config.__retryCount = config.__retryCount || 0; // 检查是否已经达到最大重试总次数
 if(config.__retryCount >= config.retry) {  // 抛出错误信息
  return Promise.reject(err);
 } // 增加请求重试次数
 config.__retryCount += 1; // 创建新的异步请求
 var backoff = new Promise(function(resolve) {  setTimeout(function() {
   resolve();
  }, config.retryDelay || 1);
 }); // 返回axios信息,重新请求
 return backoff.then(function() {  return axios(config);
 });
});

复制代码

使用:

复制代码

axios.get('/some/endpoint', { retry: 5, retryDelay: 1000 })
    .then(function(res) {
        console.log('success', res.data);
    })
    .catch(function(err) {
        console.log('failed', err);
    });

复制代码

配置参数:

retry :第一次失败请求后重试请求的次数。
retryDelay: 失败请求之间等待的毫秒数(默认为1)。上述就是请求超时处理的的方案了。

扩展 axios 自定义配置新建一个 axios 实例  请求配置信息   Requst Config   以下是开发常用的一些配置选项

axios.create([config])
var instance = axios.create({  baseURL: 'https://some-domain.com/api/',  timeout: 1000,  headers: {'X-Custom-Header': 'foobar'}
});

config配置:

复制代码

//新建 config.jsimport Qs from 'qs'{ //请求的接口,在请求的时候,如axios.get(url,config);这里的url会覆盖掉config中的url
 url: '/user', // 请求方法同上
 method: 'get', // default // 基础url前缀
 baseURL: 'https://some-domain.com/api/',    transformRequest: [function (data) {   // 这里可以在发送请求之前对请求数据做处理,比如form-data格式化等,这里可以使用开头引入的Qs(这个模块在安装axios的时候就已经安装了,不需要另外安装)  data = Qs.stringify({});  return data;
 }], transformResponse: [function (data) {  // 这里提前处理返回的数据
  return data;
 }], // 请求头信息
 headers: {'X-Requested-With': 'XMLHttpRequest'}, //parameter参数
 params: {
  ID: 12345
 }, //post参数,使用axios.post(url,{},config);如果没有额外的也必须要用一个空对象,否则会报错 data: {
  firstName: 'Fred'
 }, //设置超时时间
 timeout: 1000, //返回数据类型
 responseType: 'json', // default}


  • 2019-05-21 12:37:34

    RecyclerView 刷新闪烁

    闪烁是 notifyDataSetChange 造成的。由于适配器不知道整个数据集中的哪些内容已经存在,在重新匹配 ViewHolder 时发生的。 当然,遇到这个问题时有去搜索一些答案,看到的很多都是去禁止 RecycleView 的默认动画,可惜这对我没什么用。下面的方法是对我有用的。

  • 2019-05-21 12:43:26

    (重要)RecycleView的缓存机制

    RecycleView的四级缓存是由三个类共同作用完成的,Recycler、RecycledViewPool和ViewCacheExtension。Recycler用于管理已经废弃或者与RecyclerView分离的ViewHolder,这里面有两个重要的成员,为可以看见的屏幕的内部缓存成员mAttachedScrap、mChangedScrap和滑出屏幕外的外部缓存成员mCachedViews二者共同完成ViewHolder的缓存;RecycledViewPool类是用来缓存整体所有的ViewHolder,是对mCachedViews缓存的补充;ViewCacheExtension是扩展内的缓存对象,默认不加载,需实现方法getViewForPositionAndType(Recycler recycler, int position, int type)来实现自己的缓存。接下来对四级缓存一步步介绍。

  • 2019-05-21 12:44:31

    对嵌套RecyclerView的优化

    RecyclerView 是一个更高级的 ListView ,它可以重用view避免额外创建太多的view从而带来流畅的滚动性能。RecyclerView通过叫做 View pool 的东西持有不再可见的 view ,让它可被回收

  • 2019-05-25 14:54:50

    commit your changes or stash them before you can merge

    Your local changes to the following files would be overwritten by merge:         protected/config/main.php Please, commit your changes or stash them before you can merge. --------------------- 作者:陈小峰_iefreer 来源:CSDN 原文:https://blog.csdn.net/iefreer/article/details/7679631 版权声明:本文为博主原创文章,转载请附上博文链接!

  • 2019-05-27 10:43:34

    IntelliJ IDEA中C盘文件过大怎么办

    当我在D:\ 安装完IDEA9.0之后,建立了一个工程,发现C:\Users\Administrator\.IntelliJIdea90 竟然增大到了500+M,并且随着使用在逐渐增大,这样占用系统盘资源是非常让人不爽的,那么如何将其修改到其他路径呢?

  • 2019-05-28 13:33:20

    BRVAH+MTRVA,复杂?不存在的

    言归正传,这样的一个首页,我们需要做怎么样的基础工作呢?或者说,碰到以后更复杂的页面我们应该怎么做?这里小提示下,不要再用什么类似ScrollView的这种东西了,诶,好像说的有点绝对,尽量不要用,这不是谷歌想要看到的,5.0谷歌推出了RecyclerView,从它的整个设计架构来看,简直就是为这而生的。而RecyclerView的视图是通过Adapter来渲染的。原始的Adapter,让人很蛋疼,重复工作太多,我们应该要有封装的思想,把最需要的部分提供出来,其它不用管。