Vue axios接口封装和api管理

// 未登录则跳转登录页面,并携带当前页面的路径

// 在登录成功后返回当前页面,这一步需要在登录页操作。

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)

})

});

}

api.js

接口统一管理

import { get, post } from ‘./http’

//请求地址api

const apiAddress = query => post('/api/v1/'address, query);

//请求列表api

const apiList = query => post(‘/api/v1/list’, query);

。。。。。

export default {apiAddress,apiList}

组件中使用

import { apiAddress,apiList } from ‘@/request/api’;// 导入我们的api接口

export default {

name: ‘Address’,

created () {

this.onLoad();

},

methods: {

// 获取数据

onLoad() {

// 调用api接口,并且提供了两个参数

apiAddress({

type: 0,

sort: 1

}).then(res => {

// 获取数据成功后的其他操作

………………

})

}

}

}

创建 until,api文件夹,分别创建reques.js,index.js

reques.js如下:

import axios from ‘axios’

export function request(config){

// 创建axios对象

const service=axios.create({

baseURL:‘https://elm.cangdu.org’, // 请求源地址

timeout:5000 // 请求过期时间

})

//请求拦截器

service.interceptors.request.use((config)=>{

// 在发送请求之前做些什么

return config;

},err=>{

// 对请求错误做些什么

console.log(err)

})

//响应拦截器

service.interceptors.response.use(res=>{

// 对响应数据做点什么

// if(token过期){

// this.$router.push({path:‘/login’})

// }

return res.data

},err=>{

// 对响应错误做点什么

console.log(err)

})

return service(config)

}

index.js内容如下

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
[外链图片转存中…(img-OFOkPWjX-1715652705264)]

[外链图片转存中…(img-KuAAYBib-1715652705264)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值