vue interceptor 使用教程实例详解


Posted in Javascript onSeptember 13, 2018

二次封装axios,根据参数来实现多个请求多次拦截

1. 新建 axiosTool.js 文件,设置请求拦截和处理的逻辑

import Vue from 'vue'
import axios from 'axios'
//取消请求
let CancelToken = axios.CancelToken
//设置默认请求头,如果不需要可以取消这一步
axios.defaults.headers = {
  'X-Requested-With': 'XMLHttpRequest'
}
// 请求超时的时间限制
axios.defaults.timeout = 20000
// 开始设置请求 发起的拦截处理
// config 代表发起请求的参数的实体
axios.interceptors.request.use(config => {
  // 得到参数中的 requestName 字段,用于决定下次发起请求,取消对应的 相同字段的请求
  // 如果没有 requestName 就默认添加一个 不同的时间戳
  let requestName
  if(config.method === 'post'){
    if(config.data && config.data.requestName){
      requestName = config.data.requestName
    }else{
      requestName = new Date().getTime()
    }
  }else{
    if(config.params && config.params.requestName){
      requestName = config.params.requestName
    }else{
      requestName = new Date().getTime()
    }
  }
  // 判断,如果这里拿到的参数中的 requestName 在上一次请求中已经存在,就取消上一次的请求
  if (requestName) {
    if (axios[requestName] && axios[requestName].cancel) {
      axios[requestName].cancel()
    }
    config.cancelToken = new CancelToken(c => {
      axios[requestName] = {}
      axios[requestName].cancel = c
    })
  }
  return config
}, error => {
  return Promise.reject(error)
})
// 请求到结果的拦截处理
axios.interceptors.response.use(config => {
  // 返回请求正确的结果
  return config
}, error => {
  // 错误的请求结果处理,这里的代码根据后台的状态码来决定错误的输出信息
  if (error && error.response) {
    switch (error.response.status) {
      case 400:
        error.message = '错误请求'
        break
      case 401:
        error.message = '未授权,请重新登录'
        break
      case 403:
        error.message = '拒绝访问'
        break
      case 404:
        error.message = '请求错误,未找到该资源'
        break
      case 405:
        error.message = '请求方法未允许'
        break
      case 408:
        error.message = '请求超时'
        break
      case 500:
        error.message = '服务器端出错'
        break
      case 501:
        error.message = '网络未实现'
        break
      case 502:
        error.message = '网络错误'
        break
      case 503:
        error.message = '服务不可用'
        break
      case 504:
        error.message = '网络超时'
        break
      case 505:
        error.message = 'http版本不支持该请求'
        break
      default:
        error.message = `连接错误${error.response.status}`
    }
  } else {
    error.message = "连接到服务器失败"
  }
  return Promise.reject(error.message)
})
// 将axios 的 post 方法,绑定到 vue 实例上面的 $post
Vue.prototype.$post = function (url, params) {
  return new Promise((resolve, reject) => {
    axios.post(url, params)
      .then(res => {
        resolve(res)
      }).catch(err => {
      reject(err)
    })
  })
}
// 将axios 的 get 方法,绑定到 vue 实例上面的 $get
Vue.prototype.$get = function (url, params) {
  return new Promise((resolve, reject) => {
    axios.get(url, {
      params: params
    }).then(res => {
      resolve(res) // 返回请求成功的数据 data
    }).catch(err => {
      reject(err)
    })
  })
}
// 请求示例
// requestName 为多余的参数 作为请求的标识,下次发起相同的请求,就会自动取消上一次还没有结束的请求
// 比如正常的请求参数只有一个 name: '123',但是这里我们需要额外再加上一个 requestName
/**
  this.$post(url, { name: '123', requestName: 'post_1' })
    .then(res => {
      console.log(`请求成功:${res}`)
    })
 */
export default axios

2. 再 main.js 中引入该文件

import { axios } from './static/js/axiosTool'

3. 在组件中直接使用即可

this.$post(this.url2, {
  name: "王",
  docType: "pson",
  requestName: 'name02'
}).then(res => {
  console.log(res)
})

this.$get(this.url, {
  name: "李",
  requestName: 'name01'
}).then(res => {
  console.log(res)
})

4. 效果如图:

vue interceptor 使用教程实例详解

总结

以上所述是小编给大家介绍的vue interceptor 使用教程实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
js给onclick事件赋值,动态传参数实例解说
Mar 28 Javascript
js关于精确计算和数值格式化以及直接引js文件
Jan 28 Javascript
jquery 字符串切割函数substring的用法说明
Feb 11 Javascript
JavaScript清空数组元素的两种方法简单比较
Jul 10 Javascript
js简单实现表单中点击按钮动态增加输入框数量的方法
Aug 18 Javascript
JavaScript的继承实现小结
May 07 Javascript
jQuery Autocomplete简介_动力节点Java学院整理
Jul 17 jQuery
React教程之Props验证的具体用法(Props Validation)
Sep 04 Javascript
基于Bootstrap框架菜鸟入门教程(推荐)
Sep 17 Javascript
Vue CLI3 如何支持less的方法示例
Aug 29 Javascript
详解JavaScript中的Object.is()与"==="运算符总结
Jun 17 Javascript
vue-cli中实现响应式布局的方法
Mar 02 Vue.js
Vue点击切换颜色的方法
Sep 13 #Javascript
node中的cookie的具体使用
Sep 13 #Javascript
vue动态改变背景图片demo分享
Sep 13 #Javascript
vue vue-Router默认hash模式修改为history需要做的修改详解
Sep 13 #Javascript
详解如何在微信小程序开发中正确的使用vant ui组件
Sep 13 #Javascript
详解React中传入组件的props改变时更新组件的几种实现方法
Sep 13 #Javascript
vue 刷新之后 嵌套路由不变 重新渲染页面的方法
Sep 13 #Javascript
You might like
PHP调用Twitter的RSS的实现代码
2010/03/10 PHP
php使用qr生成二维码的示例分享
2014/01/20 PHP
php自动加载autoload机制示例分享
2014/02/20 PHP
PHP获取音频文件的相关信息
2015/06/22 PHP
SAE实时日志接口SDK用法示例
2016/10/09 PHP
TP3.2.3框架文件上传操作实例详解
2020/01/23 PHP
Jquery公告滚动+AJAX后台得到数据
2011/04/14 Javascript
JS实现悬浮移动窗口(悬浮广告)的特效
2013/03/12 Javascript
JavaScript字符串插入、删除、替换函数使用示例
2013/07/25 Javascript
javascript中的=等号个数问题两个跟三个有什么区别
2013/10/23 Javascript
利用window.name实现windowStorage代码分享
2014/01/02 Javascript
js老生常谈之this,constructor ,prototype全面解析
2016/04/05 Javascript
浅谈angularjs依赖服务注入写法的注意点
2017/04/24 Javascript
Vuejs实现购物车功能
2017/11/05 Javascript
基于angular6.0实现的一个组件懒加载功能示例
2018/04/12 Javascript
vue全局使用axios的操作
2020/09/08 Javascript
Pandas探索之高性能函数eval和query解析
2017/10/28 Python
selenium python浏览器多窗口处理代码示例
2018/01/15 Python
PyCharm更改字体和界面样式的方法步骤
2019/09/27 Python
Python原始套接字编程实例解析
2020/01/29 Python
wxpython自定义下拉列表框过程图解
2020/02/14 Python
自学python用什么系统好
2020/06/23 Python
python 图像插值 最近邻、双线性、双三次实例
2020/07/05 Python
python Zmail模块简介与使用示例
2020/12/19 Python
浏览器实现移动端高性能css3动画(开启gpu加速)
2013/12/23 HTML / CSS
详解CSS3中border-image的使用
2015/07/18 HTML / CSS
html5启动原生APP总结
2020/07/03 HTML / CSS
使用HTML5加载音频和视频的实现代码
2020/11/30 HTML / CSS
Groupon比利时官方网站:特卖和网上购物高达-70%
2019/08/09 全球购物
小学教研工作制度
2014/01/15 职场文书
初中语文教学反思
2014/02/02 职场文书
2014城乡环境综合治理工作总结
2014/12/19 职场文书
优秀党员个人总结
2015/02/14 职场文书
海底两万里读书笔记
2015/06/26 职场文书
高二语文教学反思
2016/02/16 职场文书
如何利用STAR法则制作留学文书?
2019/08/26 职场文书