简单封装axios api
可以在代码逻辑中写axios请求,处理请求结果,但是随着项目越来越大,代码会很繁琐,不容易维护,所以,可以把一些在所有请求中都要处理的逻辑抽取出来,封装成api方法。比如每次请求中都要判断是否有权限,每次请求都要携带token。
- 建一个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 - 添加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');
} - 在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
}) - 添加webapi.js:使用request.j实现对请求的拦截,封装测试前端api,传递参数,发送请求:
import request from './request' //引入request.js实现对请求前后的拦截功能
export function getTest(apiRoute) {
return request({
url: apiRoute,
method: 'get',
params: { "ai": "ai" }
})
} - 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的更多相关文章
- Vue简单封装axios—解决post请求后端接收不到参数问题
1.在src/下新建api文件夹,api/下新建index.js和public.js 在public.js中: import axios from 'axios'; import qs from 'q ...
- vue中Axios的封装和API接口的管理
前端小白的声明: 这篇文章为转载:主要是为了方便自己查阅学习.如果对原博主造成侵犯,我会立即删除. 转载地址:点击查看 如图,面对一团糟代码的你~~~真的想说,What F~U~C~K!!! 回归正题 ...
- axios简单封装
写在最前面 新手前端刚刚接触vue,感觉真的好用.项目中需要使用axios,然后学习了一下.借鉴网上一些大佬的经验,现在分享一下axios的简单封装,如果有什么错误的地方,请大家指出. axios安装 ...
- Vue中axios的封装和api接口的统一管理
更新的是我csdn上的文章,需要的话可以看下,互相学习点击去我的csdn vue中axios的封装 在vue项目和后端交互获取数据时,通常使用axios库,官方文档:https://www.npmjs ...
- 用XHR简单封装一个axios
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- [web 前端] 封装简单的axios库
转载自https://blog.csdn.net/qq_35844177/article/details/78809499 1.新建http.js文件,封装axios get post 方法 impo ...
- Vue.js(18)之 axios简单封装
基于vue-cli2.x封装axios src目录 axios.js import axios from 'axios' import { Indicator, Toast } from 'mint- ...
- Vue笔记:封装 axios 为插件使用
前言 自从Vue2.0推荐大家使用 axios 开始,axios 被越来越多的人所了解.使用axios发起一个请求对大家来说是比较简单的事情,但是axios没有进行封装复用,项目越来越大,引起的代码冗 ...
- vuex存取token,http简单封装、模拟登入权限校验操作、路由懒加载的几种方式、vue单页设置title
1.config index.js下面的跨域代理设置: proxyTable: { '/api': { target: 'http://xxxx', //要访问的后端接口 changeOrigin: ...
随机推荐
- PRINT语句详解
首先摘自联机丛书中的PRINT语法如下: PRINT msg_str | @local_variable | string_exp 以上可看出PRINT语句的输出参数均为字符或字符串的常量或变量 - ...
- [arc079f] Namori Grundy 分类讨论
Description 给给全有一个NN个点NN条边的有向图,点的的编号从11到NN 给给全的图有NN条边,形如:(p1,1),(p2,2),...,(pN,N)(p1,1),(p2,2),...,( ...
- 【扫盲】HTML5、Web APP、3G网站、Wap网站傻傻分不清楚
移动互联网指手机网站和app,其中app分为native app(原生app),web app(html5开发),Hybrid app(前两种app结合):手机网站分为wap网站和3g网 ...
- 总结day1 ---- 基础内容学习 ,以及历史了解
知识目录 一 : python 的发展历史 1. pyhton2 和pyhton3 的区别 二: python的语言分类 三 :变量 四: 常量 五 :注释 六 : 基本数据类型 1 : int 2 ...
- PHP错误——Allowed memory size of 134217728 bytes exhausted (tried to allocate 32 bytes)
解释是可用内存已耗尽,这关系到PHP的memory_limit的设置问题. 这里有两种方法解决 1.修改php.ini memory_limit = 128 打开终端输入下列bash命令 cd /pr ...
- 支付宝支付下载对账单bug反馈整理
支付宝官方给广大开发朋友们,留了一个下载账单的API接口,供大家下载指定日期的账单数据.先来看下这个页面: 点我前往官方说明文档 $aop = new AopClient (); $aop->g ...
- #.NET# DataGrid显示大量数据——DataGridView虚模式
要解决的目标:如何让 Datagridview 快速平滑显示大量数据 通常,Winform 下的表格控件是很"低效"的,如 DataGrid 和 DataGridView.造成低效 ...
- 【性能测试】:LR插入mysql数据库数据,脚本参数化问题
一,今天准备脚本做mysql数据库的铺地数据,脚本内容不赘述,在批量执行insert语句时候,出现一个问题: // sprintf(chQuery, "insert into table ( ...
- 01背包-记忆化搜索到成型的DP
记忆化搜索 #include<bits/stdc++.h> using namespace std; typedef long long ll; int n,W; int dp[105][ ...
- [转] Mock以及Mockito的使用
http://www.open-open.com/lib/view/open1462177583813.html [From] http://www.open-open.com/lib/view/op ...