可以在代码逻辑中写axios请求,处理请求结果,但是随着项目越来越大,代码会很繁琐,不容易维护,所以,可以把一些在所有请求中都要处理的逻辑抽取出来,封装成api方法。比如每次请求中都要判断是否有权限,每次请求都要携带token。

  1. 建一个request.js文件,对请求的服务的拦截

    import axios from 'axios'
    
    // create an axios instance,根据需要写入配置信息
    const service = axios.create({
    // baseURL: process.env.BASE_API, // api的base_url
    // timeout: 5000,
    //headers: { 'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8' },//method: 'get', //一般需要用post
    // request timeout
    }) // request interceptor 请求之前的拦截器
    service.interceptors.request.use(config => {
    // Do something before request is sent
    return config
    }, error => {
    // Do something with request error
    console.log(error) // for debug
    Promise.reject(error)
    }) // respone interceptor 请求之后异常状态拦截
    service.interceptors.response.use(
    response => {
    const res = response.data;
    if (res.statusCode === || res.statusCode === || res.statusCode === || res.statusCode === || res.statusCode === ) {
    return Promise.reject('error');
    } else {
    return response.data;
    }
    },
    error => {
    console.log('err' + error)// for debug
    return Promise.reject(error)
    }
    ) export default service
  2. 添加auth.js文件,本地缓存实现对用户信息缓存的读写和移除,代码:
    //与用户验证相关的方法
    
    export function getToken() {
    //从localstorage获取token
    return localStorage.getItem('token');
    } export function setToken(token) {
    //本地缓存存储token
    localStorage.setItem('token', token);
    } export function removeToken() {
    //本地缓存移除token
    localStorage.removeItem('token');
    } export function getUserId() {
    //从本地缓存中获取userID
    return localStorage.getItem("userid");
    } export function setUserId(userid) {
    //本地缓存存储userId
    localStorage.setItem('userid', userid);
    } export function removeUserId() {
    //本地缓存移除userId
    localStorage.removeItem('userid');
    } export function getProjectId() {
    //从本地缓存中获取projectid
    return localStorage.getItem("projectid");
    } export function setProjectId(projectid) {
    //本地缓存存储projectid
    localStorage.setItem('projectid', projectid);
    } export function removeProjectId() {
    //本地缓存移除projectid
    localStorage.removeItem('projectid');
    }
  3. 在store.js中,添加如下对auth.js的使用,和状态管理:
    import Vue from 'vue'
    import Vuex from 'vuex'
    import { getToken, setToken, removeToken, getUserId, setUserId, getProjectId, setProjectId, removeUserId, removeProjectId } from '../Utils/auth.js' Vue.use(Vuex); /*访问状态对象--存放变量*/
    const state = {
    token: getToken(),
    userId: getUserId(),
    projectId: getProjectId()
    }
    /*访问触发对象--存放事件*/
    const mutations = {
    SET_TOKEN: (state, token) => {
    setToken(token);
    //state.token = token;
    //localStorage.setItem('token', token);
    },
    SET_USER_ID: (state, m) => {
    setUserId(m);
    },
    SET_PRO_ID: (state, m) => {
    state.projectId = m;
    setProjectId(m);
    }, //用户注销后删除所有本地数据
    LOGOUT: (state) => {
    removeToken();
    removeUserId();
    removeProjectId();
    }
    }
    export default new Vuex.Store({
    state,
    mutations
    })
  4. 添加webapi.js:使用request.j实现对请求的拦截,封装测试前端api,传递参数,发送请求:
    import request from './request'  //引入request.js实现对请求前后的拦截功能
    export function getTest(apiRoute) {
    return request({
    url: apiRoute,
    method: 'get',
    params: { "ai": "ai" }
    })
    }
  5. webApi在组件中的使用
      //按需引入封装好的webapi的方法   
      import { getTest } from "../../Utils/webapi.js";
    export default{
    //测试前端api的使用,在创建的时候发送请求,获取项目信息
    created: function() {
    var _this = this;
    //test
    getTest("/project/test").then(response => {
    _this.testapi = response.data;
    });
    },
    }

该例子是针对项目的简单封装和使用例子,具体的axios的配置和相关知识可以看下一遍文章介绍

    

简单封装axios api的更多相关文章

  1. Vue简单封装axios—解决post请求后端接收不到参数问题

    1.在src/下新建api文件夹,api/下新建index.js和public.js 在public.js中: import axios from 'axios'; import qs from 'q ...

  2. vue中Axios的封装和API接口的管理

    前端小白的声明: 这篇文章为转载:主要是为了方便自己查阅学习.如果对原博主造成侵犯,我会立即删除. 转载地址:点击查看 如图,面对一团糟代码的你~~~真的想说,What F~U~C~K!!! 回归正题 ...

  3. axios简单封装

    写在最前面 新手前端刚刚接触vue,感觉真的好用.项目中需要使用axios,然后学习了一下.借鉴网上一些大佬的经验,现在分享一下axios的简单封装,如果有什么错误的地方,请大家指出. axios安装 ...

  4. Vue中axios的封装和api接口的统一管理

    更新的是我csdn上的文章,需要的话可以看下,互相学习点击去我的csdn vue中axios的封装 在vue项目和后端交互获取数据时,通常使用axios库,官方文档:https://www.npmjs ...

  5. 用XHR简单封装一个axios

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. [web 前端] 封装简单的axios库

    转载自https://blog.csdn.net/qq_35844177/article/details/78809499 1.新建http.js文件,封装axios get post 方法 impo ...

  7. Vue.js(18)之 axios简单封装

    基于vue-cli2.x封装axios src目录 axios.js import axios from 'axios' import { Indicator, Toast } from 'mint- ...

  8. Vue笔记:封装 axios 为插件使用

    前言 自从Vue2.0推荐大家使用 axios 开始,axios 被越来越多的人所了解.使用axios发起一个请求对大家来说是比较简单的事情,但是axios没有进行封装复用,项目越来越大,引起的代码冗 ...

  9. vuex存取token,http简单封装、模拟登入权限校验操作、路由懒加载的几种方式、vue单页设置title

    1.config index.js下面的跨域代理设置: proxyTable: { '/api': { target: 'http://xxxx', //要访问的后端接口 changeOrigin: ...

随机推荐

  1. iOS 错误 undefined symbols for architecture i386

    undefined symbols for architecture i386 这个错误困扰了我几个小时. 网上很多问这个问题的,回答基本上都是说在 target 里面去的 armv64 什么什么的. ...

  2. c语言第六次作业---结构体&文件

    1.本章学习总结 1.1思维导图 1.2学习体会 这次应该是本学期最后一次博客了,总结一下这个学期的学习,一开始就基础薄弱还一直畏难一直懒惰,不想去解决问题导致后面问题越来越多就觉得学习越来越难,后面 ...

  3. js简单正则表达式验证密码

    包含3种及以上 var reg = new RegExp("^(?![A-Za-z]+$)(?![A-Z\\d]+$)(?![A-Z\\W]+$)(?![a-z\\d]+$)(?![a-z\ ...

  4. centos绑定https

    1.百度云申请免费ssl证书 一年一申请 2. https://www.wosign .com /faq/faq-apache-https.htm 3.注意ssl.conf里面各个证书的顺序 证书路径 ...

  5. linux下查找命令总结

    查找命令总结,which,whereis,find,locate,type http://blog.csdn.net/jessica1201/article/details/8139249   1.f ...

  6. leetcode-54-螺旋矩阵

    题目描述: 给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素. 示例 1: 输入: [ [ 1, 2, 3 ], [ 4, 5, 6 ], [ 7 ...

  7. 基于CH340的一键下载电路

    一.CH340简介 CH340 是一个 USB 总线的转接芯片,实现 USB 转串口或者 USB 转打印口.CH340是国产芯片,应用场合居多,市场占有率很高.常用的USB转串口芯片还有CP2102. ...

  8. [原创]SSH 隧道转发

    目录 简介 本地SSH隧道 远程SSH隧道 FAQ 免密码登陆 自动重连 简介 建立ssh隧道常用于, 通过一台公网的主机或者是大家都可以访问的主机做跳转机,来访问内部或者外部不能直接访问的机器. 项 ...

  9. 南昌网络赛 Distance on the tree 主席树+树剖 (给一颗树,m次查询ui->vi这条链中边权小于等于ki的边数。)

    https://nanti.jisuanke.com/t/38229 题目: 给一颗树,m次查询ui->vi这条链中边权小于等于ki的边数. #include <bits/stdc++.h ...

  10. 01背包-记忆化搜索到成型的DP

    记忆化搜索 #include<bits/stdc++.h> using namespace std; typedef long long ll; int n,W; int dp[105][ ...