带你玩转vue——简约清晰的vue封装axios(ajax)方法

简介: 带你玩转vue——简约清晰的vue封装axios(ajax)方法

前言


局部刷新技术技术的出现与应用大大推动了web工程的成熟与发展。其中以ajax与axios最为突出,但是不管是哪种方式,我们每次发起请求都会重复对http参数进行设置,并对请求后的数据进行异常数据处理等,作为一名优秀的面向对象的软件攻城狮怎么能够容忍,所以笔者遍访各大网站与前同事、同学总结出一套简单明了的封装方式!


项目结构


如下图所示,名称为demo的演示项目

image.png

其中utils中存放的即是封装的axios组件


代码鉴赏


1、首先在store中声明baseUrl,用于存放请求路径的公共部分,同时声明一个修改公共路径的方法editBaseUrl:

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
export default new Vuex.Store({
  state: {
    baseUrl: 'http://127.0.0.1:8001'
  },
  mutations: {
    editBaseUrl: (state, val) => {
      state.menus = val
    }
  },
  actions: {
  },
  modules: {
  }
})


2、在新建的request.js文件中引入axios与store:


import axios from 'axios';

import store from '@/store';


3、声明一个axios对象:


const service = axios.create({
  method: 'post',//http请求方式
  baseURL: store.state.baseUrl, // 默认公用url
  withCredentials: true, // 跨域请求
  timeout: 10000 // 请求超时时间
});

4、设置拦截器,每次发起http请求前进行拦截,并将请求秘钥注入http请求头:


service.interceptors.request.use(
  config => {
    //getToken为自定义方法,用于获取在store或cookie中的token,token为用户使用账号及密码置换的秘钥
    config.headers.Authorization = getToken();
    return config;
  },
  error => {
    return Promise.reject(error);
  }
)


设置拦截器,对请求的返回值进行拦截,并对返回结果进行初步处理:

service.interceptors.response.use(
  response => {
    //拿到返回数据
    const res = response.data;
    //res结构为{code:0,data:{},mes:{}},其中code为错误码,0为未报错,data为返回数据,mes为错误信息
    if (res.code != undefined) {
      //请求未报错,将数据摘出并返回
      if (res.code === 0) {
        return res.data;
      }
      //请求报错
      else {
        //将错误信息弹窗
        alert(res.msg);
        //特定错误码,登录超时,将前端存储在store中和cookie中的token删除并返回登录页
        if (res.code === 106) {
          removeToken();
          router.push('/');
        }
        return Promise.reject(res.msg || 'error');
      }
    }
  },
  //请求未能连接成功
  error => {
    //console.log('err' + error); // for debug
    alert(error.message);
    return Promise.reject(error);
  }
)

5、定义输出接口:

export default service;


6、调用:

在api文件夹中定义js文件


import request from '@/utils/request';
export function getPage(data) {
  return request({
    url: '/api/account/v1/getPage',//请求url=http://127.0.0.1:8001/api/account/v1/getPage
    data: data
  })
}


拓展


许多小伙伴在前后端分离之后会遇到这样一个问题:开发人员发布版本之后将前端项目打包发给运维同事,但是如何我们上面在设置baseUrl时直接将其写死在store中,如果后端地址发生改变,如何才能不用重新打包即可部署呢?


如上图在index.html中加入以下代码:


<script>
    window.config = {
      Host: 'http://127.0.0.1:8001/'//访问后端地址
    };
</script>


并在App.vue初始化时,将该参数提交至store中即可:


mounted: function () {
    store.commit( "editBaseUrl", window.config.Host);
}


相关文章
|
4天前
|
JavaScript API
Vue中如何完成对axios的二次封装、统一接口管理
这篇文章介绍了在Vue项目中如何对axios进行二次封装,实现接口的统一管理和简化请求过程,包括创建api包、编写request.js、在main.js中引入封装好的axios以及在项目中发送请求的方法。
Vue中如何完成对axios的二次封装、统一接口管理
|
19天前
|
存储 开发框架 前端开发
基于SqlSugar的开发框架循序渐进介绍(10)-- 利用axios组件的封装,实现对后端API数据的访问和基类的统一封装处理
基于SqlSugar的开发框架循序渐进介绍(10)-- 利用axios组件的封装,实现对后端API数据的访问和基类的统一封装处理
|
2月前
|
JavaScript
vue对axios封装
vue对axios封装
34 2
|
1月前
|
JSON 数据格式
axios发送post请求,如何接受和返回一个axios的字段,解决bug的方法,困难的事情先从简单做起,先从发送一个axios的post请求做起,解决方法查别人的资料,查看F12看network就行
axios发送post请求,如何接受和返回一个axios的字段,解决bug的方法,困难的事情先从简单做起,先从发送一个axios的post请求做起,解决方法查别人的资料,查看F12看network就行
|
1月前
vue3 在 watchEffect 里中断未完成的 axios 请求(只保留最后一次请求的方法---连续点击查询按钮的优化)
vue3 在 watchEffect 里中断未完成的 axios 请求(只保留最后一次请求的方法---连续点击查询按钮的优化)
29 0
|
1月前
|
前端开发
网页设计,若依项目修改(It must be done)02------axios封装后发get请求,axios请求的位置在呢?
网页设计,若依项目修改(It must be done)02------axios封装后发get请求,axios请求的位置在呢?
|
2月前
|
XML 前端开发 JavaScript
异步请求$.ajax()方法详解
异步请求$.ajax()方法详解
|
3月前
|
存储 算法 JavaScript
< 今日小技巧:Axios封装,接口请求增加防抖功能 >
今天这篇文章,主要是讲述对axios封装的请求,由于部分请求可能存在延时的情况。使得接口可能存在会被持续点击(即:接口未响应的时间内,被持续请求),导致重复请求的问题,容易降低前后端服务的性能!故提出给axios封装的配置里面,新增一个防抖函数,用来限制全局请求的防抖。
< 今日小技巧:Axios封装,接口请求增加防抖功能 >
|
3月前
|
缓存 前端开发 JavaScript
前端vue3分享——项目封装axios、vite使用env环境变量
前端vue3分享——项目封装axios、vite使用env环境变量
170 0
|
9月前
|
XML 前端开发 JavaScript
什么是Ajax和jquery
什么是Ajax和jquery
70 0