axios create拦截_axios拦截设置和错误处理方法

现在vue的官方包已经不更新vue-resource了,转而推荐axios,下面是项目实战是总结的axios插件设置:

/**

* @file Axios的Vue插件(添加全局请求/响应拦截器)

*/

// https://github.com/mzabriskie/axios

import axios from 'axios'

// 拦截request,设置全局请求为ajax请求

axios.interceptors.request.use((config) => {

config.headers['X-Requested-With'] = 'XMLHttpRequest'

return config

})

// 拦截响应response,并做一些错误处理

axios.interceptors.response.use((response) => {

const data = response.data

// 根据返回的code值来做不同的处理(和后端约定)

switch (data.code) {

case '0':

// 举例

// exp: 修复iPhone 6+ 微信点击返回出现页面空白的问题

if (isIOS()) {

// 异步以保证数据已渲染到页面上

setTimeout(() => {

// 通过滚动强制浏览器进行页面重绘

document.body.scrollTop += 1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值