Vue的axios封装

Vue的axios封装Vue 的 axios 封装在 vue 项目中 经常需要封装 axios 文档又看不懂 所以总结一下方法 安装 npminstallax 安装 axios 引入在项目的 src 目录中 新建一个 request 文件夹 然后在里面新建一个 http js 和一个 api js 文件 http js 文件用来封装我们的 axios api js 用来统一管理我们的接口 在 http js 中引入 axiosimporta axios 引入 axiosimportQ

Vue的axios封装

在vue项目中,经常需要封装axios,文档又看不懂。所以总结一下方法。

  1. 安装
 npm install axios; // 安装axios 
  1. 引入
    在项目的src目录中,新建一个request文件夹,然后在里面新建一个http.js和一个api.js文件。http.js文件用来封装我们的axios,api.js用来统一管理我们的接口。
    // 在http.js中引入axios

import axios from 'axios'; // 引入axios 
import QS from 'qs'; // 引入qs模块 
import { 
    Toast } from 'vant'; 
  1. 环境切换
    我们的项目环境可能有开发环境、测试环境和生产环境。我们通过node的环境变量来匹配我们的默认的接口url前缀。axios.defaults.baseURL可以设置axios的默认请求地址就不多说了。
    // 环境的切换

if (process.env.NODE_ENV == 'development') { 
    axios.defaults.baseURL = 'https://www.baidu.com';} else if (process.env.NODE_ENV == 'debug') { 
    axios.defaults.baseURL = 'https://www.ceshi.com'; } else if (process.env.NODE_ENV == 'production') { 
    axios.defaults.baseURL = 'https://www.production.com'; } 
  1. 设置请求超时
    通过axios.defaults.timeout设置默认的请求超时时间。例如超过了10s,就会告知用户当前请求超时,请刷新等。
axios.defaults.timeout = 10000; 
  1. 请求头设置
    post请求的时候,我们需要加上一个请求头,所以可以在这里进行一个默认的设置,即设置post的请求头为
application/x-www-form-urlencoded;charset=UTF-8 axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8'; 
 // 先导入vuex,因为我们要使用到里面的状态对象 // vuex的路径根据自己的路径去写 import store from '@/store/index'; // 请求拦截器axios.interceptors.request.use(  config => { 
    // 每次发送请求之前判断vuex中是否存在token  // 如果存在,则统一在http请求的header都加上token,这样后台根据token判断你的登录情况 // 即使本地存在token,也有可能token是过期的,所以在响应拦截器中要对返回状态进行判断  const token = store.state.token; token && (config.headers.Authorization = token); return config; }, error => { 
    return Promise.error(error); }) 
 // 响应拦截器 axios.interceptors.response.use( response => { 
    // 如果返回的状态码为200,说明接口请求成功,可以正常拿到数据  // 否则的话抛出错误 if (response.status === 200) { 
    return Promise.resolve(response); } else { 
    return Promise.reject(response); } }, // 服务器状态码不是2开头的的情况 // 这里可以跟你们的后台开发人员协商好统一的错误状态码  // 然后根据返回的状态码进行一些操作,例如登录过期提示,错误提示等等 // 下面列举几个常见的操作,其他需求可自行扩展 error => { 
    if (error.response.status) { 
    switch (error.response.status) { 
    // 401: 未登录 // 未登录则跳转登录页面,并携带当前页面的路径 // 在登录成功后返回当前页面,这一步需要在登录页操作。  case 401: router.replace({ 
    path: '/login', query: { 
    redirect: router.currentRoute.fullPath } }); break; // 403 token过期 // 登录过期对用户进行提示 // 清除本地token和清空vuex中token对象 // 跳转登录页面  case 403: Toast({ 
    message: '登录过期,请重新登录', duration: 1000, forbidClick: true }); // 清除token localStorage.removeItem('token'); store.commit('loginSuccess', null); // 跳转登录页面,并将要浏览的页面fullPath传过去,登录成功后跳转需要访问的页面  setTimeout(() => { 
    router.replace({ 
    path: '/login', query: { 
    redirect: router.currentRoute.fullPath } }); }, 1000); break; // 404请求不存在 case 404: Toast({ 
    message: '网络请求不存在', duration: 1500, forbidClick: true }); break; // 其他错误,直接抛出错误提示 default: Toast({ 
    message: error.response.data.message, duration: 1500, forbidClick: true }); } return Promise.reject(error.response); } } }); 

响应拦截器很好理解,就是服务器返回给我们的数据,我们在拿到之前可以对他进行一些处理。例如上面的思想:如果后台返回的状态码是200,则正常返回数据,否则的根据错误的状态码类型进行一些我们需要的错误,其实这里主要就是进行了错误的统一处理和没登录或登录过期后调整登录页的一个操作。

/ * get方法,对应get请求 * @param {String} url [请求的url地址] * @param {Object} params [请求时携带的参数] */ export function get(url, params){ 
    return new Promise((resolve, reject) =>{ 
    axios.get(url, { 
    params: params }).then(res => { 
    resolve(res.data); }).catch(err =>{ 
    reject(err.data) }) });} 

post方法:原理同get基本一样,但是要注意的是,post方法必须要使用对提交从参数对象进行序列化的操作,所以这里我们通过node的qs模块来序列化我们的参数。这个很重要,如果没有序列化操作,后台是拿不到你提交的数据的。这就是文章开头我们import QS from ‘qs’;的原因。如果不明白序列化是什么意思的,就百度一下吧,答案一大堆。

/ * post方法,对应post请求 * @param {String} url [请求的url地址] * @param {Object} params [请求时携带的参数] */ export function post(url, params) { 
    return new Promise((resolve, reject) => { 
    axios.post(url, QS.stringify(params)) .then(res => { 
    resolve(res.data); }) .catch(err =>{ 
    reject(err.data) }) }); } 

这里有个小细节说下,axios.get()方法和axios.post()在提交数据时参数的书写方式还是有区别的。区别就是,get的第二个参数是一个{},然后这个对象的params属性值是一个参数对象的。而post的第二个参数就是一个参数对象。两者略微的区别要留意哦!

最后说一下api的统一管理

整齐的api就像电路板一样,即使再复杂也能很清晰整个线路。上面说了,我们会新建一个api.js,然后在这个文件中存放我们所有的api接口。

首先我们在api.js中引入我们封装的get和post方法

/

  • api接口统一管理
    */
import { 
    get, post } from './http' 

现在,例如我们有这样一个接口,是一个post请求:

export const apiAddress = p => post('api/v1/users/my_address/address_edit_before', p); 

我们定义了一个apiAddress方法,这个方法有一个参数p,p是我们请求接口时携带的参数对象。而后调用了我们封装的post方法,post方法的第一个参数是我们的接口地址,第二个参数是apiAddress的p参数,即请求接口时携带的参数对象。最后通过export导出apiAddress。

然后在我们的页面中可以这样调用我们的api接口:

import { 
    apiAddress } from '@/request/api';// 导入我们的api接口 export default { 
    name: 'Address', created () { 
    this.onLoad(); }, methods: { 
    // 获取数据  onLoad() { 
    // 调用api接口,并且提供了两个参数  apiAddress({ 
    type: 0, sort: 1 }).then(res => { 
    // 获取数据成功后的其他操作 ……………… }) } } } 

其他的api接口,就在pai.js中继续往下面扩展就可以了。友情提示,为每个接口写好注释哦!!!

api接口管理的一个好处就是,我们把api统一集中起来,如果后期需要修改接口,我们就直接在api.js中找到对应的修改就好了,而不用去每一个页面查找我们的接口然后再修改会很麻烦。关键是,万一修改的量比较大,就规格gg了。还有就是如果直接在我们的业务代码修改接口,一不小心还容易动到我们的业务代码造成不必要的麻烦。

好了,最后把完成的axios封装代码奉上。

/axios封装 * 请求拦截、相应拦截、错误统一处理 */ import axios from 'axios'; import QS from 'qs'; import { 
    Toast } from 'vant'; import store from '../store/index' // 环境的切换 if (process.env.NODE_ENV == 'development') { 
    axios.defaults.baseURL = '/api'; } else if (process.env.NODE_ENV == 'debug') { 
    axios.defaults.baseURL = ''; } else if (process.env.NODE_ENV == 'production') { 
    axios.defaults.baseURL = 'http://api.123dailu.com/'; } // 请求超时时间 axios.defaults.timeout = 10000; // post请求头 axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8'; // 请求拦截器 axios.interceptors.request.use( config => { 
    // 每次发送请求之前判断是否存在token,如果存在,则统一在http请求的header都加上token,不用每次请求都手动添加了 // 即使本地存在token,也有可能token是过期的,所以在响应拦截器中要对返回状态进行判断 const token = store.state.token; token && (config.headers.Authorization = token); return config; }, error => { 
    return Promise.error(error); }) // 响应拦截器 axios.interceptors.response.use( response => { 
    if (response.status === 200) { 
    return Promise.resolve(response); } else { 
    return Promise.reject(response); } }, // 服务器状态码不是200的情况  error => { 
    if (error.response.status) { 
    switch (error.response.status) { 
    // 401: 未登录  // 未登录则跳转登录页面,并携带当前页面的路径  // 在登录成功后返回当前页面,这一步需要在登录页操作。  case 401: router.replace({ 
    path: '/login', query: { 
    redirect: router.currentRoute.fullPath } }); break; // 403 token过期  // 登录过期对用户进行提示  // 清除本地token和清空vuex中token对象  // 跳转登录页面  case 403: Toast({ 
    message: '登录过期,请重新登录', duration: 1000, forbidClick: true }); // 清除token  localStorage.removeItem('token'); store.commit('loginSuccess', null); // 跳转登录页面,并将要浏览的页面fullPath传过去,登录成功后跳转需要访问的页面 setTimeout(() => { 
    router.replace({ 
    path: '/login', query: { 
    redirect: router.currentRoute.fullPath } }); }, 1000); break; // 404请求不存在  case 404: Toast({ 
    message: '网络请求不存在', duration: 1500, forbidClick: true }); break; // 其他错误,直接抛出错误提示  default: Toast({ 
    message: error.response.data.message, duration: 1500, forbidClick: true }); } return Promise.reject(error.response); } } ); / * get方法,对应get请求 * @param {String} url [请求的url地址] * @param {Object} params [请求时携带的参数] */ export function get(url, params){ 
    return new Promise((resolve, reject) =>{ 
    axios.get(url, { 
    params: params }) .then(res => { 
    resolve(res.data); }) .catch(err => { 
    reject(err.data) }) }); } / * post方法,对应post请求 * @param {String} url [请求的url地址] * @param {Object} params [请求时携带的参数] */ export function post(url, params) { 
    return new Promise((resolve, reject) => { 
    axios.post(url, QS.stringify(params)) .then(res => { 
    resolve(res.data); }) .catch(err => { 
    reject(err.data) }) }); } 

如果喜欢,就给个❤吧

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

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233543.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • win7 boot设置_重装系统boot missing

    win7 boot设置_重装系统boot missing转自 http://blog.wsdd.org/安装linux,vista/win7双系统后,怎么引导是个问题理论上,可以从windows的bootloader引导linux,也可以linux的grub引导windows但windows更霸道,经常霸占MBR,所以最好是linux不放MBR,然后从windows的bootloader引导linux把linux装在自己的分区,不要

    2022年10月12日
    0
  • Vue新手入门指南(易懂)

    Vue新手入门指南(易懂)Vue.js学习心得前言对于一名初入编程的新手来说,JavaScript的语法偏向复杂,选择Vue库可以说是一个较为不错的体验。在很多方面,Vue简化了JavaScrip语法,并且实现数据与视图的双向绑定,达到响应式页面的目的。1.Vue实例和模板语法<body> <divid=”app”> <p>{{message}}</p> </div><script> newVue({ el:’#app’

    2022年5月4日
    38
  • 用通俗易懂的大白话讲解Map/Reduce原理「建议收藏」

    用通俗易懂的大白话讲解Map/Reduce原理「建议收藏」下面是我自己的微信公众号(不定期更新JAVA、大数据、个人成长等干货)1、公众号上有经典的技术电子书可以免费领2、大家有问题可以在公众号问我,只要你问了我就会回复(相互交流)也可以扫描下面二维码,加我个人微信,和我直接沟通Hadoop简介Hadoop就是一个实现了Google云计算系统的开源系统,包括并行计算模型Map/Reduce,分布式文件系统HDFS,以及……

    2022年7月26日
    1
  • 用java实现图片切换_电视背景集成墙面

    用java实现图片切换_电视背景集成墙面下载openCV官网地址:Releases-OpenCV下载地址:DownloadOpenCVfromSourceForge.net这里我用的opencv440的windows版本下载完成后点击exe进行安装,安装完成后会生成opencv文件夹,里面有各个环境文件boot示例1.在opencv\build\java\以及opencv\build\java\x64下提取jar包以及动态库。2.在resources下创建lib/opencv文件夹,并将..

    2022年9月17日
    0
  • 散列表采用线性探测法会出现_平方探测法解决冲突

    散列表采用线性探测法会出现_平方探测法解决冲突第一、前言ThreadLocal使用的是自定义的ThreadLocalMap,接下来我们来探究一下ThreadLocalMap的hash冲突解决方式。第二、ThreadLocal的set()方法publicvoidset(Tvalue){Threadt=Thread.currentThread();ThreadLocal.ThreadLocalMapmap=getMap(t);if(map!=null)map.set(this,

    2022年10月21日
    0
  • 工作流引擎 Activiti 万字详细入门

    工作流引擎 Activiti 万字详细入门Activiti7一、工作流介绍1.1概念工作流(Workflow),就是通过计算机对业务流程自动化执行管理。它主要解决的是“使在多个参与者之间按照某种预定义的规则自动进行传递文档、信息或任务的过程,从而实现某个预期的业务目标,或者促使此目标的实现”。1.2工作流系统一个软件系统中具有工作流的功能,我们把它称为工作流系统,一个系统中工作流的功能是什么?就是对系统的业务流程进行自动化管理,所以工作流是建立在业务流程的基础上,所以一个软件的系统核心根本上还是系统的业务流程,工作流只是协助进行业务流

    2022年7月11日
    22

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号