面试题:项目中如何封装axios请求
创始人
2025-05-29 20:14:39
0

项目中如何封装axios请求

文章目录

  • 项目中如何封装axios请求
      • 项目中如何封装axios请求
      • 什么是请求拦截?什么是响应拦截?
          • 请求拦截:
          • 响应拦截:

项目中如何封装axios请求

在前端中,我们通常会使用 axios 这个库来进行 HTTP 请求。为了方便管理和复用,我们可以对 axios 请求进行封装。目的是用来方便复用

  • 我们通过 axios.create() 方法创建了一个 axios 实例,设置了基础 URL、超时时间和请求头信息。

  • 然后,我们对这个实例设置了请求拦截器和响应拦截器,用于在请求和响应过程中做一些统一的处理

  • 最后,我们通过导出一个包含常用请求方法的对象来对 axios 进行了封装

    import axios from 'axios'const aa = axios.create({baseURL: 'https://api.example.com',timeout: 5000,headers: {'Content-Type': 'application/json'}
    })// 请求拦截器
    aa.interceptors.request.use(config => {// 在发送请求之前做些什么//例如  判断是否存在token,如果存在将每个页面header都添加tokenreturn config
    }, error => {// 对请求错误做些什么return Promise.reject(error)
    })// 响应拦截器
    aa.interceptors.response.use(response => {// 对响应数据做些什么// 例如  如果是401错误,说明token没有 或 过期,就跳转登录页return response.data
    }, error => {// 对响应错误做些什么return Promise.reject(error)
    })

什么是请求拦截?什么是响应拦截?

请求拦截器和响应拦截器是 axios 提供的拦截器机制,用于在 HTTP 请求和响应的过程中,对请求和响应进行统一的处理。

请求拦截:

请求拦截是在发送请求之前进行拦截请求,并且在请求发送出去之前进行修改。

在请求拦截中,我们可以对请求头进行统一的设置,对请求参数进行加密或者是验证的操作

响应拦截:

响应拦截是在接收到响应之后进行拦截,并在响应被处理之前进行修改

请求结果返回时,先不直接导出,而是对响应数据先进行处理

同时,响应拦截器还可以处理网络请求的异常情况

总之,请求拦截器和响应拦截器是 axios 提供的非常有用的拦截器机制,能够帮助我们统一处理 HTTP 请求和响应,提高代码的复用性和可维护性,同时还能够提高应用程序的健壮性和稳定性。

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...