首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
第 14 章 基于Vue的网络框架vue-axios的应用
14.1 使用vue-axios请求天气数据
14.1.1 使用互联网上免费的数据服务
14.1.2 使用vue-axios进行数据请求
14.2 vue-axios实用功能介绍
14.2.1 通过配置的方式进行数据请求
14.2.2 请求的配置与响应数据结构
14.2.3 拦截器的使用
14.3 实战:天气预报应用
14.3.1 搭建页面框架
14.3.2 实现天气预报应用核心逻辑
第 15 章 Vue路由管理
15.1 Vue Router的安装与简单使用
15.1.1 Vue Router的安装
15.1.2 一个简单的Vue Router的使用示例
15.2 带参数的动态路由
15.2.1 路由参数匹配
15.2.2 路由匹配的语法规则
15.2.3 路由的嵌套
15.3 页面导航
15.3.1 使用路由方法
15.3.2 导航历史控制
15.4 关于路由的命名
15.4.1 使用名称进行路由切换
15.4.2 路由视图命名
15.4.3 使用别名
15.4.4 路由重定向
15.5 关于路由传参
15.6 路由导航守卫
15.6.1 定义全局的导航守卫
15.6.2 为特定的路由注册导航守卫
15.7 动态路由
第 16 章 Vue状态管理
16.1 认识Vuex框架
16.1.1 关于状态管理
16.1.2 安装与体验Vuex
16.2 Vuex中的一些核心概念
16.2.1 Vuex中的状态state
16.2.2 Vuex中的Getter方法
16.2.3 Vuex中的Mutation
16.2.4 Vuex中的Action
16.2.5 Vuex中的Module 333
当前位置:
首页>>
技术小册>>
TypeScript和Vue从入门到精通(五)
小册名称:TypeScript和Vue从入门到精通(五)
### 14.2.3 拦截器的使用 在开发大型或复杂的前端应用时,特别是当涉及到与后端API的交互时,请求的发送与响应的处理往往成为关键的性能与优化点。Vue.js 结合 TypeScript 的项目中,通过引入HTTP客户端库(如Axios)并巧妙地使用拦截器(Interceptors),可以极大地提升代码的可维护性、复用性和错误处理能力。本章节将深入探讨在Vue.js与TypeScript环境下,如何使用Axios拦截器来优化网络请求与响应的处理流程。 #### 14.2.3.1 拦截器概述 拦截器是Axios提供的一种强大的机制,允许你在请求被发送到服务器之前或响应从服务器返回之后,对它们进行拦截并处理。这种机制非常适合于全局性的错误处理、请求/响应数据的格式化、设置请求头、添加令牌认证等场景。 Axios的拦截器分为两类: - **请求拦截器**(Request Interceptors):在请求发送之前执行。 - **响应拦截器**(Response Interceptors):在接收到响应之后执行。 #### 14.2.3.2 设置请求拦截器 请求拦截器主要用于在请求发送之前对请求进行预处理,如添加统一的请求头、处理请求数据等。以下是一个在Vue.js与TypeScript环境中设置请求拦截器的示例: ```typescript // src/plugins/axios.ts import axios, { AxiosInstance, AxiosRequestConfig, AxiosResponse } from 'axios'; // 创建一个axios实例 const service: AxiosInstance = axios.create({ baseURL: process.env.VUE_APP_BASE_API, // api的base_url timeout: 5000 // 请求超时时间 }); // 请求拦截器 service.interceptors.request.use( (config: AxiosRequestConfig) => { // 在发送请求之前做些什么 // 例如,设置token if (store.getters.token) { config.headers['Authorization'] = `Bearer ${store.getters.token}`; } // 当你想对请求数据做点什么 if (config.method === 'post') { // 假设config.data是请求体 config.data = JSON.stringify(config.data); } return config; }, (error) => { // 对请求错误做些什么 console.error('请求拦截器捕获到错误:', error); return Promise.reject(error); } ); export default service; ``` 在这个例子中,我们创建了一个axios实例,并为其配置了基本的URL和超时时间。然后,我们为这个实例添加了一个请求拦截器,它在每个请求发送前都会被调用。在这个拦截器内部,我们检查了Vuex存储中的token(如果应用使用了Vuex进行状态管理),并将其添加到请求头中以实现身份验证。此外,我们还对POST请求的请求体进行了JSON字符串化处理。 #### 14.2.3.3 设置响应拦截器 响应拦截器用于在接收到响应后进行一系列处理,如处理错误响应、统一响应数据格式等。以下是一个响应拦截器的示例: ```typescript // 响应拦截器 service.interceptors.response.use( (response: AxiosResponse) => { // 对响应数据做点什么 // 例如,根据响应状态码进行错误处理 const res = response.data; if (response.status !== 200) { console.error('接口响应错误:', response.status); // 这里可以抛出一个错误,由Vue的错误处理机制捕获 return Promise.reject(new Error('接口响应错误')); } else { // 假设后端统一返回的数据结构为{code, data, message} if (res.code !== 200) { // 自定义业务错误处理 return Promise.reject(new Error(res.message || 'Error')); } else { // 返回正常数据 return res.data; } } }, (error) => { // 对响应错误做点什么 // 例如,网络错误的处理 console.error('响应拦截器捕获到错误:', error); return Promise.reject(error); } ); ``` 在这个响应拦截器中,我们首先检查HTTP状态码,如果不是200,则直接打印错误信息并拒绝这个Promise,这样就可以通过Vue的错误处理机制(如全局错误处理器或组件内的catch语句)来捕获这个错误。然后,我们检查后端返回的业务状态码(这里假设后端统一了返回格式),如果业务状态码也不表示成功,则同样拒绝Promise并返回错误信息。只有当HTTP状态码和业务状态码都表示成功时,我们才返回实际的响应数据。 #### 14.2.3.4 拦截器的移除 在某些情况下,你可能需要移除之前添加的拦截器,特别是在组件或页面销毁时,以避免内存泄漏或不必要的请求/响应处理。Axios提供了`eject`方法来移除拦截器,但需要注意的是,这个方法在Axios 0.21.0及之前的版本中并不存在,它是一个社区提出的建议但并未正式加入Axios。不过,你可以通过维护拦截器的引用并使用`interceptors.request.eject`或`interceptors.response.eject`(如果这些方法被实现或模拟)来尝试移除拦截器。然而,更常见和推荐的做法是,在组件或页面销毁时不再发送新的请求,让现有的请求自然完成,并通过Vue的生命周期钩子或路由守卫来管理请求的取消或重试逻辑。 #### 14.2.3.5 实战应用 在实际项目中,拦截器的使用远不止于上述示例。例如,你可以在请求拦截器中根据环境变量动态设置API的基准URL,或者在响应拦截器中实现自动重试机制(对于可重试的错误类型)。此外,你还可以利用拦截器来集成日志记录系统,将请求和响应数据发送到日志服务器进行监控和分析。 总之,拦截器是Axios提供的一个非常强大的功能,通过合理使用拦截器,你可以极大地提升Vue.js与TypeScript项目中网络请求的处理效率和可维护性。不过,也需要注意不要过度使用拦截器,特别是在请求/响应处理逻辑复杂时,应该考虑将逻辑拆分成更小的函数或服务,以保持代码的清晰和可测试性。
上一篇:
14.2.2 请求的配置与响应数据结构
下一篇:
14.3 实战:天气预报应用
该分类下的相关小册推荐:
TypeScript和Vue从入门到精通(二)
TypeScript和Vue从入门到精通(四)
移动端开发指南
Vue原理与源码解析
TypeScript和Vue从入门到精通(三)
TypeScript和Vue从入门到精通(一)
Vue.js从入门到精通(一)
vue项目构建基础入门与实战
Vue面试指南
Vue源码完全解析
vuejs组件实例与底层原理精讲
Vue.js从入门到精通(四)