在vue中如何实现axios二次封装

本篇文章主要介绍了vue axios 二次封装的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

这段时间告诉项目需要,用到了vue。

刚开始搭框架的时候用的是vue-resource后面看到官方推荐axios就换过来了 顺便封装了一下

//引入axiosimport axios from 'axios'let cancel ,promiseArr = {}const CancelToken = axios.CancelToken;//请求拦截器axios.interceptors.request.use(config => { //发起请求时,取消掉当前正在进行的相同请求 if (promiseArr[config.url]) {  promiseArr[config.url]('操作取消')  promiseArr[config.url] = cancel } else {  promiseArr[config.url] = cancel }  return config}, error => { return Promise.reject(error)})//响应拦截器axios.interceptors.response.use(response => { return response}, error => { return Promise.resolve(error.response)})axios.defaults.baseURL = '/api'//设置默认请求头axios.defaults.headers = { 'X-Requested-With': 'XMLHttpRequest'}axios.defaults.timeout = 10000export default { //get请求 get (url,param) {  return new Promise((resolve,reject) => {  axios({   method: 'get',   url,   params: param,   cancelToken: new CancelToken(c => {   cancel = c   })  }).then(res => {   resolve(res)  })  }) }, //post请求 post (url,param) {  return new Promise((resolve,reject) => {  axios({   method: 'post',   url,   data: param,   cancelToken: new CancelToken(c => {   cancel = c   })  }).then(res => {   resolve(res)  })  })  } }

登录后复制

说明

1、为防止发起请求时,当前正在进行的相同请求,在请求拦截器中加入了hash判断,将相同请求url拦截

立即学习“前端免费学习笔记(深入)”;

2、将axios中get,post公共配置抽离出来

axios.defaults.baseURL = '/api'//设置默认请求头axios.defaults.headers = { 'X-Requested-With': 'XMLHttpRequest'}axios.defaults.timeout = 10000

登录后复制

3、get,post请求的封装 可能你会问,这里的axios返回的就是promise对象,为什么还要再次对get,post封装一次promise.因为我这边的话,在开发中使用async await会出现数据请求失败的情况,报的错就是返回的不是promise对象。(ps:可async await返回的就是promise呀,这个问题后续再搞一下)就直接return了一个promise对象,以避免上面的错误。下面是请求接口的一个例子

import req from '../api/requestType'/** * 拼团详情 */export const groupDetail = param => { return req.get('/RestHome/GroupDetail',param)}

登录后复制

下面是数据的获取

async getData() { const params = {  TopCataID: 0,  pageNumber: this.pageNumber,  pageSize: this.pageSize } const res = await groupList(params)},

登录后复制

到这里我们就简单的封装了一下适合自己项目的axios

封装理由:

1、可以和后端商量好错误码在这统一提示统一处理,省去不必要的麻烦

2、如果做接口全报文加解密都可以在此处理

接口统一归类: 

const serviceModule = {  getLocation: {  url: ' service/location/transfor',  method: 'get'  } } const ApiSetting = {...serviceModule }  export default ApiSetting

登录后复制

归类好处:

1、后期接口升级或者接口名更改便于维护

http调用:

 import http from "../../lib/http.js"; import ApiSetting from "../../lib/ApiSetting.js"; export default {  created: function() {  http(ApiSetting.getLocation,{"srChannel": "h5",})  .then((res)=>{   console.log(res)  },(error)=>{   console.log(error)   })  },  methods: {   } } 

登录后复制

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

详细解读Angular5.1新功能

详细解读Angular5.1新功能

详细解读Angular5.1新功能

详细解读Angular5.1新功能

详细解读Angular5.1新功能

以上就是在vue中如何实现axios二次封装的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2749661.html

(0)
上一篇 2025年3月8日 05:04:09
下一篇 2025年2月18日 04:44:06

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 如何通过全局方法使用Vue.use()组件

    本篇文章主要介绍了vue自定义全局组件并通过全局方法 vue.use() 使用该组件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 简介 Vue.use( plugin ):安装 Vue.js 插件。如果插件是一个对象,必须提供 ins…

    编程技术 2025年3月8日
    200
  • 在vue中如何使用路由参数传递

    这篇文章主要给大家介绍了关于vue中路由参数传递遇到的坑的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。 前言 vue中路由跳转传参数有多种,自己常用的是下面…

    编程技术 2025年3月8日
    200
  • 在Vue中如何控制全局console.log开关

    这篇文章主要给大家介绍了关于vue根据url传参如何控制全局console.log开关的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起看看吧。 前言 最近在学习vue,发现了一个…

    编程技术 2025年3月8日
    200
  • 使用Vue如何制作组织架构树组件

    最近公司在做一个基于vue开发的项目,项目需要开发一个展示组织架构的树组件,在网上搜了半天,没有找到合适的,下面小编给大家分享一个基于vue制作组织架构树组件,需要的朋友参考下吧 由于公司业务需求,需要开发一个展示组织架构的树组件(公司的项…

    2025年3月8日 编程技术
    200
  • 使用vue如何制作Tab组件

    这篇文章主要给大家介绍了关于利用vue组件自定义v-model实现一个tab组件的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。 前言 最近在学习vue,今天…

    2025年3月8日
    200
  • 如何重置vue打印变量的显示方式(详细教程)

    这篇文章主要给大家介绍了关于如何重置vue打印变量显示方式的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起看看吧。 前言 我们在日常开发中,经常会碰到vue使用conso…

    2025年3月8日
    200
  • 在vue中有关cli使用绝对路径引用问题

    这篇文章主要给大家介绍了关于vue cli使用绝对路径引用图片问题的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起看看吧。 前言 Vue是什么,是一套构建用户界面的渐进式…

    编程技术 2025年3月8日
    200
  • 在vue中如何实现picker效果

    这篇文章主要介绍了vue 实现 ios 原生picker 效果及实现思路解析,本文给大家介绍的非常详细,具有参考借鉴价值,需要的朋友可以参考下 以前最早实现了一个类似的时间选择插件,但是适用范围太窄,索性最近要把这个实现方式发布出来,就重写…

    2025年3月8日 编程技术
    200
  • 在Vue中有关DevTools调试工具的使用方法

    本篇文章主要介绍了vue devtools调试工具的使用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 因为工作要求,目前主要在用Vue.js技术栈做开发,调试是必不可少的,这里会用的Vue DevTools的…

    2025年3月8日 编程技术
    200
  • 如何解决把Vue项目部署到服务器上出现的问题

    本篇文章主要介绍了vue 项目部署到服务器的问题解决方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 相信很多小伙伴在用Vue-cli安装的脚手架开发的时候,在开发环境中项目可以很正常的运行,但是进入到生产环…

    2025年3月8日
    200

发表回复

登录后才能评论