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 相关文章推荐
基于jQuery的Tab选项框效果代码(插件)
Mar 01 Javascript
网页下载文件期间如何防止用户对网页进行其他操作
Jun 27 Javascript
jQuery实现表格展开与折叠的方法
May 04 Javascript
JavaScript知识点总结(五)之Javascript中两个等于号(==)和三个等于号(===)的区别
May 31 Javascript
jQuery实现div横向拖拽排序的简单实例
Jul 13 Javascript
关于Vue背景图打包之后访问路径错误问题的解决
Nov 03 Javascript
详解vue中使用微信jssdk
Apr 19 Javascript
vue的keep-alive中使用EventBus的方法
Apr 23 Javascript
Vue 权限控制的两种方法(路由验证)
Aug 16 Javascript
JS+html5实现异步上传图片显示上传文件进度条功能示例
Nov 09 Javascript
微信小程序以ssm做后台开发的实现示例
Apr 08 Javascript
JavaScript实现点击图片换背景
Nov 20 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
js tab 选项卡
2009/04/26 Javascript
深入解析JavaScript中的变量作用域
2013/12/06 Javascript
jQuery表格排序组件-tablesorter使用示例
2014/05/26 Javascript
node.js正则表达式获取网页中所有链接的代码实例
2014/06/03 Javascript
获取中文字符串的实际长度代码
2014/06/05 Javascript
基于socket.io和node.js搭建即时通信系统
2014/07/30 Javascript
JQuery组件基于Bootstrap的DropDownList(完整版)
2016/07/05 Javascript
jQuery实现手机上输入后隐藏键盘功能
2017/01/04 Javascript
node.js程序作为服务并在windows下开机自启动(用forever)
2017/03/29 Javascript
javascript 中null和undefined区分和比较
2017/04/19 Javascript
详解vue.js移动端导航navigationbar的封装
2017/07/05 Javascript
Vuejs 页面的区域化与组件封装的实现
2017/09/11 Javascript
Array数组对象中的forEach、map、filter及reduce详析
2018/08/02 Javascript
浅谈vue中组件绑定事件时是否加.native
2019/11/09 Javascript
JS实现简单的表格增删
2020/01/16 Javascript
Vue Object 的变化侦测实现代码
2020/04/15 Javascript
JavaScript实现复选框全选和取消全选
2020/11/20 Javascript
[03:03]2014DOTA2西雅图国际邀请赛 Alliance战队巡礼
2014/07/07 DOTA
[44:30]完美世界DOTA2联赛PWL S2 GXR vs Magma 第一场 11.25
2020/11/26 DOTA
python实现每次处理一个字符的三种方法
2014/10/09 Python
Python实现的简单模板引擎功能示例
2017/09/02 Python
python通过百度地图API获取某地址的经纬度详解
2018/01/28 Python
python实现决策树、随机森林的简单原理
2018/03/26 Python
numpy.random模块用法总结
2019/05/27 Python
python实现二分类和多分类的ROC曲线教程
2020/06/15 Python
利用CSS3实现圆角的outline效果的教程
2015/06/05 HTML / CSS
澳大利亚足球鞋和服装购物网站:Ultra Football
2018/10/11 全球购物
德国电子产品购物网站:TechInTheBasket德国
2018/12/07 全球购物
Radley英国官网:英国莱德利小狗包
2019/03/21 全球购物
PHP两种查询函数array/row的区别
2013/06/03 面试题
某公司C#程序员面试题笔试题
2014/05/26 面试题
军训自我鉴定
2013/12/14 职场文书
大学校园毕业自我鉴定
2014/01/15 职场文书
幼儿教师演讲稿
2014/05/06 职场文书
Qt自定义Plot实现曲线绘制的详细过程
2021/11/02 Python
MySQL数据库Innodb 引擎实现mvcc锁
2022/05/06 MySQL