axios使用拦截器统一处理所有的http请求的方法


Posted in Javascript onNovember 02, 2018

axios使用拦截器

  在请求或响应被 then 或 catch 处理前拦截它们。

http request拦截器

// 添加请求拦截器
axios.interceptors.request.use(function (config) {
  // 在发送请求之前做些什么
  return config;
 }, function (error) {
  // 对请求错误做些什么
  return Promise.reject(error);
 });

http respones拦截器

// 添加响应拦截器
axios.interceptors.response.use(function (response) {
  // 对响应数据做点什么
  return response;
 }, function (error) {
  // 对响应错误做点什么
  return Promise.reject(error);
 });

移除拦截器

var myInterceptor = axios.interceptors.request.use(function () {/*...*/});
axios.interceptors.request.eject(myInterceptor);

为自定义axios实例添加拦截器

var instance = axios.create();
instance.interceptors.request.use(function () {/*...*/});

PS:下面看下axios拦截器使用

import axios from 'axios' // axios引用
import store from '../../store' // store引用
const serivce = axios.create({ // 创建服务
 baseURL: 'http://test.api.rujiaowang.net', // 基础路径
 timeout: 5000 // 请求延时
})
serivce.interceptors.request.use( // 请求拦截
 config => {
  if (store.getters.userToken) {
   config.headers['X-Token'] = store.getters.userToken
   config.headers['User-Type'] = store.getters.userType ? store.getters.userType : '' // 请求头中存放用户信息
   config.onUploadProgress = (progressEvent) => {
    var complete = (progressEvent.loaded / progressEvent.total * 100 | 0) + '%'
    store.dispatch('setupLoadPercent', complete)
   }
  }
  return config
 },
 error => {
  return Promise.reject(error)
 }
)
serivce.interceptors.response.use( // 回复拦截,主要针对部分回掉数据状态码进行处理
 response => {
  return response
 },
 error => {
  return Promise.reject(error)
 }
)
export default serivce

总结

以上所述是小编给大家介绍的axios使用拦截器统一处理所有的http请求的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
利用js 进行输入框自动匹配字符的小例子
Jun 29 Javascript
深入理解JavaScript中的传值与传引用
Dec 09 Javascript
BOOTSTRAP时间控件显示在模态框下面的bug修复
Feb 05 Javascript
JavaScript模拟鼠标右键菜单效果
Dec 08 Javascript
JQuery核心函数是什么及使用方法介绍
May 03 Javascript
jquery实现点击弹出可放大居中及关闭的对话框(附demo源码下载)
May 10 Javascript
jQuery中$.grep() 过滤函数 数组过滤
Nov 22 Javascript
jQuery、layer实现弹出层的打开、关闭功能
Jun 28 jQuery
详解Vue路由钩子及应用场景(小结)
Nov 07 Javascript
解决vue同一slot在组件中渲染多次的问题
Sep 06 Javascript
这应该是最详细的响应式系统讲解了
Jul 22 Javascript
微信小程序实现上传照片代码实例解析
Aug 04 Javascript
vue实现与安卓、IOS交互的方法
Nov 02 #Javascript
解决iview多表头动态更改列元素发生的错误的方法
Nov 02 #Javascript
JavaScript 点击触发复制功能实例详解
Nov 02 #Javascript
微信小程序实现留言板(Storage)
Nov 02 #Javascript
微信小程序实现留言板功能
Nov 02 #Javascript
小程序实现留言板
Nov 02 #Javascript
js中的闭包实例展示
Nov 01 #Javascript
You might like
mysql,mysqli,PDO的各自不同介绍
2012/09/19 PHP
实例讲解PHP面向对象之多态
2014/08/20 PHP
PHP制作3D扇形统计图以及对图片进行缩放操作实例
2014/10/23 PHP
利用PHP生成静态html页面的原理
2016/09/30 PHP
PHP获取用户客户端真实IP的解决方案
2016/10/10 PHP
javascript的键盘控制事件说明
2008/04/15 Javascript
css值转换成数值请抛弃parseInt
2011/10/24 Javascript
PassWord输入框代码分享
2016/06/07 Javascript
微信小程序(应用号)开发新闻客户端实例
2016/10/24 Javascript
js 取消页面可以选中文字的功能方法
2018/01/02 Javascript
Vue组件中slot的用法
2018/01/30 Javascript
vue.js获得当前元素的文字信息方法
2018/03/09 Javascript
微信小程序点击view动态添加样式过程解析
2020/01/21 Javascript
JavaScript异步操作的几种常见处理方法实例总结
2020/05/11 Javascript
JavaScript中ES6规范中let和const的用法和区别
2020/08/06 Javascript
使用JavaScript和MQTT开发物联网应用示例解析
2020/08/07 Javascript
python发送arp欺骗攻击代码分析
2014/01/16 Python
Python中暂存上传图片的方法
2015/02/18 Python
简单谈谈python中的多进程
2016/11/06 Python
超简单使用Python换脸实例
2019/03/27 Python
python中使用ctypes调用so传参设置遇到的问题及解决方法
2019/06/19 Python
PyTorch的深度学习入门之PyTorch安装和配置
2019/06/27 Python
基于python的列表list和集合set操作
2019/11/24 Python
Python编写单元测试代码实例
2020/09/10 Python
HTML5 Canvas实现玫瑰曲线和心形图案的代码实例
2014/04/10 HTML / CSS
香港钟表珠宝首饰商城:OneMallTime网摩间
2016/10/14 全球购物
韩都衣舍天猫官方旗舰店:天猫女装销售总冠军
2017/10/10 全球购物
客服部工作职责范本
2014/02/14 职场文书
技术总监管理岗位职责
2014/03/09 职场文书
绩效管理实施方案
2014/03/19 职场文书
代理词怎么写
2015/05/25 职场文书
西安事变观后感
2015/06/12 职场文书
同意报考证明
2015/06/17 职场文书
装修公司管理制度
2015/08/05 职场文书
学生会主席任命书
2015/09/21 职场文书
详解JS数组方法
2021/11/20 Javascript