Spring Boot + Vue 前后端分离开发,前端网络请求封装与配置

本文介绍了如何在前端项目中使用axios进行网络请求的封装,包括安装、配置请求拦截器和响应拦截器,以统一处理各种错误情况并推荐使用ElementUI的Massage组件展示错误信息。
摘要由CSDN通过智能技术生成

===================================================================

axios 使用步骤很简单,首先在前端项目中,引入 axios:

npm install axios -S

装好之后,按理说可以直接使用了,但是,一般在生产环境中,我们都需要对网络请求进行封装。

因为网络请求可能会出错,这些错误有的是代码错误导致的,也有的是业务错误,不管是哪一种错误,都需要开发者去处理,而我们不可能在每一次发送请求时都去枚举各种错误情况。

因此我们需要对前端请求进行封装,封装完成后,将前端错误统一处理,这样,开发者只需要在每一次发送请求的地方处理请求成功的情况即可。

请求封装

===============================================================

在 axios 中,我们可以使用 axios 自带的拦截器来实现对错误的统一处理。

在 axios 中,有请求拦截器,也有响应拦截器。

请求拦截器中可以统一添加公共的请求参数,例如单点登录中前端统一添加 token 参数。

响应拦截器则可以实现对错误的统一处理。

另外一个需要注意的地方则是错误的展示需要使用一种通用的方式,而不可以和页面绑定(例如,登录失败,在用户名/密码输入框后面展示错误信息,不支持这种错误显示方式),这里推荐使用 ElementUI 中的 Massage 来展示错误信息,这是一个页面无关的组件。

封装后的 axios 如下:

import axios from ‘axios’

import {Message} from ‘element-ui’

axios.interceptors.request.use(config => {

return config;

}, err => {

Message.error({message: ‘请求超时!’});

})

axios.interceptors.response.use(data => {

if (data.status && data.status == 200 && data.data.status == 500) {

Message.error({message: data.data.msg});

return;

}

if (data.data.msg) {

Message.success({message: data.data.msg});

}

return data.data;

}, err => {

if (err.response.status == 504 || err.response.status == 404) {

Message.error({message: ‘服务器被吃了⊙﹏⊙∥’});

} else if (err.response.status == 403) {

Message.error({message: ‘权限不足,请联系管理员!’});

} else if (err.response.status == 401) {

Message.error({message: err.response.data.msg});

} else {

if (err.response.data.msg) {

Message.error({message: err.response.data.msg});

}else{

Message.error({message: ‘未知错误!’});

}

}

})

代码解释:

  1. 首先导入 axios 和 Massage 组件

  2. 接下来定义一个请求拦截器

  3. 最后定义一个响应拦截器,这个拦截器有两个参数,第一个参数 data 表示服务端处理成功的响应,第二个 err 表示服务端处理失败的响应。对照着 jQuery 中的 Ajax ,第一个相当于 success 回调,第二个相当于 error 回调。

  4. 响应的 data 表示服务端返回的数据,数据格式是 {data:{status:200,msg"",obj:{}},status:200} 其中,data 中的对象就是服务端返回的具体的 JSON ,外面的 status 表示 HTTP 响应码,里边的 status 是自定义的 RespBean 中返回的数据

  5. 首先判断 HTTP 响应码为 200 ,并且服务端返回的 status 为 500 ,表示业务逻辑错误,此时直接通过 Message 将错误信息展示出来,然后 return 即可。

  6. 如果服务端返回的字段中包含 msg ,则将 msg 显示出来,这个 msg 一般是成功的提示。

  7. 最后返回 data.data ,即将服务端返回的数据 return ,这个数据最终会来到请求调用的地方。

  8. 当 HTTP 响应码大于等于 400 时,进入 err 中。

方法封装

===============================================================

请求封装完成后,还需要对方法进行封装,方便调用:

let base = ‘’;

export const postRequest = (url, params) => {

return axios({

method: ‘post’,

url: ${base}${url},

data: params,

headers: {

‘Content-Type’: ‘application/json’

}

});

}

export const putRequest = (url, params) => {

return axios({

method: ‘put’,

url: ${base}${url},

data: params,

headers: {

‘Content-Type’: ‘application/json’

}

});

}

export const deleteRequest = (url) => {

return axios({

method: ‘delete’,

url: ${base}${url}

});

}

export const getRequest = (url) => {

return axios({

method: ‘get’,

url: ${base}${url}

});

}

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

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

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

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

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

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

打开全栈工匠技能包-1小时轻松掌握SSR

两小时精通jq+bs插件开发

生产环境下如歌部署Node.js

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

网易内部VUE自定义插件库NPM集成

谁说前端不用懂安全,XSS跨站脚本的危害

webpack的loader到底是什么样的?两小时带你写一个自己loader

zIwZV9oZC5qcGc?x-oss-process=image/format,png)

谁说前端不用懂安全,XSS跨站脚本的危害

webpack的loader到底是什么样的?两小时带你写一个自己loader

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值