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代码
Nov 20 Javascript
JavaScript 原型链学习总结
Oct 29 Javascript
详解JavaScript函数绑定
Aug 18 Javascript
jquery弹出框的用法示例(一)
Aug 26 Javascript
跟我学习javascript的undefined与null
Nov 17 Javascript
vue+springboot前后端分离实现单点登录跨域问题解决方法
Jan 30 Javascript
vue项目国际化vue-i18n的安装使用教程
Mar 14 Javascript
如何以Angular的姿势打开Font-Awesome详解
Apr 22 Javascript
vue实现个人信息查看和密码修改功能
May 06 Javascript
Vue.js 中的实用工具方法【推荐】
Jul 04 Javascript
javascript设计模式 ? 职责链模式原理与用法实例分析
Apr 16 Javascript
vue实现单一筛选、删除筛选条件
Oct 26 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
PHP mail()函数使用及配置方法
2014/01/14 PHP
解决更换PHP5.4以上版本后Dedecms后台登录空白问题的方法
2015/10/23 PHP
简单概括PHP的字符串中单引号与双引号的区别
2016/05/07 PHP
Yii配置与使用memcached缓存的方法
2016/07/13 PHP
详解thinkphp5+swoole实现异步邮件群发(SMTP方式)
2017/10/13 PHP
PHP+mysql防止SQL注入的方法小结
2019/04/27 PHP
在多个页面使用同一个HTML片段《续》
2011/03/04 Javascript
JavaScript控制各种浏览器全屏模式的方法、属性和事件介绍
2014/04/03 Javascript
angularjs的一些优化小技巧
2014/12/06 Javascript
JS实现点击上移下移LI行数据的方法
2015/08/05 Javascript
在ASP.NET MVC项目中使用RequireJS库的用法示例
2016/02/15 Javascript
jQuery事件的绑定、触发、及监听方法简单说明
2016/05/10 Javascript
JavaScript Ajax编程 应用篇
2016/07/02 Javascript
Bootstrap 布局组件(全)
2016/07/18 Javascript
js基础之DOM中元素对象的属性方法详解
2016/10/28 Javascript
微信小程序实现图片自适应(支持多图)
2017/01/25 Javascript
浅谈vue实现数据监听的函数 Object.defineProperty
2017/06/08 Javascript
React操作真实DOM实现动态吸底部的示例
2017/10/23 Javascript
three.js中文文档学习之通过模块导入
2017/11/20 Javascript
Angular2进阶之如何避免Dom误区
2018/04/02 Javascript
基于vue中对鼠标划过事件的处理方式详解
2018/08/22 Javascript
ES6中的class是如何实现的(附Babel编译的ES5代码详解)
2019/05/17 Javascript
vue-drag-chart 拖动/缩放图表组件的实例代码
2020/04/10 Javascript
Python常见异常分类与处理方法
2017/06/04 Python
python @property的用法及含义全面解析
2018/02/01 Python
解决matplotlib库show()方法不显示图片的问题
2018/05/24 Python
python aiohttp的使用详解
2019/06/20 Python
python 实现list或string按指定分段
2019/12/25 Python
windows、linux下打包Python3程序详细方法
2020/03/17 Python
python实现控制台输出颜色
2021/03/02 Python
通信研究生自荐信
2014/02/01 职场文书
便利店投资创业计划书
2014/02/08 职场文书
教师产假请假条
2014/04/10 职场文书
学校节能减排倡议书
2014/05/16 职场文书
个人承诺书怎么写
2014/05/24 职场文书
windows server 2016 域环境搭建的方法步骤(图文)
2022/06/25 Servers