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 相关文章推荐
[原创]站长必须要知道的javascript广告代码
May 30 Javascript
IE和Firefox下javascript的兼容写法小结
Dec 10 Javascript
关于innerHTML后丢失动态绑定的EVENT问题解决方法
May 19 Javascript
JavaScript分秒倒计时器实现方法
Feb 02 Javascript
jQuery获取及设置表单input各种类型值的方法小结
May 24 Javascript
ionic 上拉菜单(ActionSheet)实例代码
Jun 06 Javascript
JS面试题---关于算法台阶的问题
Jul 26 Javascript
Vuejs第一篇之入门教程详解(单向绑定、双向绑定、列表渲染、响应函数)
Sep 09 Javascript
js实现日期显示的一些操作(实例讲解)
Jul 27 Javascript
利用Node.js如何实现文件循环覆写
Apr 05 Javascript
vue--vuex详解
Apr 15 Javascript
使用Vant完成Dialog弹框案例
Nov 11 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
如何限制访问者的ip(PHPBB的代码)
2006/10/09 PHP
PDO防注入原理分析以及使用PDO的注意事项总结
2014/10/23 PHP
PHP实现的随机IP函数【国内IP段】
2016/07/20 PHP
PHP基于Closure类创建匿名函数的方法详解
2017/08/17 PHP
PHP封装XML和JSON格式数据接口操作示例
2019/03/06 PHP
Yii2.0框架模型添加/修改/删除数据操作示例
2019/07/18 PHP
namespace.js Javascript的命名空间库
2011/10/11 Javascript
深入理解JavaScript系列(6):S.O.L.I.D五大原则之单一职责SRP
2012/01/15 Javascript
jQuery实现图片放大预览实现原理及代码
2013/09/12 Javascript
基于Jquery+Ajax+Json实现分页显示附效果图
2014/07/30 Javascript
JQuery中ajax方法访问web服务实例
2015/07/18 Javascript
jquery实现点击变换导航样式的方法
2015/08/31 Javascript
jquery原理以及学习技巧介绍
2015/11/11 Javascript
JS兼容所有浏览器的DOMContentLoaded事件
2018/01/12 Javascript
原生JS实现随机点名项目的实例代码
2019/04/30 Javascript
jQuery实现图片下载代码
2019/07/18 jQuery
js实现掷骰子小游戏
2019/10/24 Javascript
JavaScript实现简单的弹窗效果
2020/05/19 Javascript
解决vue-router 切换tab标签关闭时缓存问题
2020/07/22 Javascript
[46:10]2014 DOTA2国际邀请赛中国区预选赛 CnB VS HGT
2014/05/21 DOTA
[15:20]DOTA2-DPC中国联赛 正赛 Elephant vs Aster 选手采访
2021/03/11 DOTA
gearman的安装启动及python API使用实例
2014/07/08 Python
详解Python中的正则表达式的用法
2015/04/09 Python
Python使用matplotlib和pandas实现的画图操作【经典示例】
2018/06/13 Python
Python logging自定义字段输出及打印颜色
2020/11/30 Python
详解pycharm的python包opencv(cv2)无代码提示问题的解决
2021/01/29 Python
留学推荐信中文范文三篇
2014/01/25 职场文书
保密普查工作实施方案
2014/02/25 职场文书
教师考核材料
2014/05/21 职场文书
专题民主生活会对照检查材料思想汇报
2014/09/29 职场文书
暂停营业通知
2015/04/25 职场文书
小区物业管理2015年度工作总结
2015/10/22 职场文书
导游词之湖北武当山
2019/09/23 职场文书
Redis安装启动及常见数据类型
2021/04/14 Redis
Python实现列表拼接和去重的三种方式
2021/07/02 Python
Win11远程连接不上怎么办?Win11远程桌面用不了的解决方法
2022/08/05 数码科技