【前端】基于 Promise 的 HTTP 客户端工具Axios 详解

Axios 详解


1. 简介
  • 定义:Axios 是一个基于 Promise 的 HTTP 客户端,用于浏览器和 Node.js 环境,简化 HTTP 请求的发送和处理。
  • 核心特点
    • 支持 Promise API,可链式调用。
    • 自动转换 JSON 数据。
    • 支持请求/响应拦截。
    • 可取消请求。
    • 客户端支持防抖和跨域请求。

2. 核心功能
功能 描述
GET/POST 请求 发送 GETPOST 等 HTTP 方法请求。
Promise 支持 通过 .then().catch() 处理异步操作。
拦截器 在请求发送前或响应返回后拦截并修改请求/响应数据。
取消请求 通过 CancelToken 取消未完成的请求。
响应类型 支持 response.dataresponse.status 等详细响应信息。

3. 基本用法示例
javascript 复制代码
// 安装(Node.js 环境)
npm install axios

// 发送 GET 请求
axios.get('/api/users', {
  params: { id: 1 } // 查询参数
})
.then(response => {
  console.log(response.data);
})
.catch(error => {
  console.error('Error:', error);
});

// 发送 POST 请求
axios.post('/api/create', {
  name: 'Alice',
  age: 25
}, {
  headers: { 'Content-Type': 'application/json' }
})
.then(response => console.log(response.data))
.catch(error => console.error(error));

4. 配置选项
配置项 描述
baseURL 请求的基础路径(全局或实例配置)。
timeout 请求超时时间(毫秒)。
headers 自定义请求头(如 Authorization)。
withCredentials 是否允许跨域请求携带凭证(如 Cookie)。
paramsSerializer 自定义参数序列化函数(如处理对象为 URL 参数)。
javascript 复制代码
// 全局配置示例
axios.defaults.baseURL = 'https://api.example.com';
axios.defaults.timeout = 5000;

5. 拦截器
  • 请求拦截器:在请求发送前修改配置:

    javascript 复制代码
    axios.interceptors.request.use(config => {
      // 添加 Token
      config.headers.Authorization = `Bearer ${localStorage.token}`;
      return config;
    }, error => Promise.reject(error));
  • 响应拦截器:在响应返回后处理数据或错误:

    javascript 复制代码
    axios.interceptors.response.use(response => {
      return response.data; // 简化后续 .then() 的数据获取
    }, error => {
      if (error.response.status === 401) {
        // 处理未授权错误(如跳转登录页)
      }
      return Promise.reject(error);
    });

6. 错误处理
  • 常见错误类型
    • error.response:包含状态码和响应数据(如 404、500)。
    • error.request:请求已发送但无响应。
    • error.message:其他错误信息(如网络问题)。
javascript 复制代码
axios.get('/api/invalid')
.catch(error => {
  if (error.response) {
    console.log('Status:', error.response.status);
    console.log('Error Data:', error.response.data);
  } else {
    console.log('Request Failed:', error.message);
  }
});

7. 与 Fetch 的对比
特性 Axios Fetch
Promise 支持 原生支持 原生支持
请求/响应拦截 支持 不支持
取消请求 支持 需通过 AbortController 实现
JSON 自动解析 自动转换 需调用 response.json()
浏览器兼容性 兼容性好(需 polyfill 旧版浏览器) 需 polyfill IE 等旧版浏览器

8. 常见场景
  • 跨域请求 :通过 CORS 配置或代理解决(如在开发环境配置代理)。

  • 上传文件

    javascript 复制代码
    const file = document.querySelector('input[type="file"]').files[0];
    const formData = new FormData();
    formData.append('file', file);
    axios.post('/api/upload', formData, {
      headers: { 'Content-Type': 'multipart/form-data' }
    });

9. 最佳实践
  1. 避免全局配置污染 :通过 axios.create() 创建实例,隔离不同环境配置。
  2. 统一错误处理:通过拦截器集中处理 Token 过期、网络错误等通用问题。
  3. 取消重复请求:在组件卸载时取消未完成的请求,避免内存泄漏。
  4. 合理设置超时 :根据接口复杂度调整 timeout 防止阻塞。
javascript 复制代码
// 创建实例示例
const apiClient = axios.create({
  baseURL: '/api',
  timeout: 10000
});
相关推荐
邝邝邝邝丹19 分钟前
React学习———React Router
前端·学习·react.js
正在走向自律37 分钟前
GpuGeek 网络加速:破解 AI 开发中的 “最后一公里” 瓶颈
网络·人工智能·python·机器学习·性能优化·gpugeek
Yvonne爱编码44 分钟前
CSS- 2.1 实战之图文混排、表格、表单
前端·css·html·github·状态模式·html5·hbuilder
前端小巷子1 小时前
CSS面试题汇总
前端·css·面试
绝美焦栖1 小时前
vue复杂数据类型多层嵌套的监听
前端·javascript·vue.js
laocooon5238578862 小时前
一台入网的电脑有6要素, 机器名,mac,ip,俺码,网关,dns,分别有什么作用
网络协议·tcp/ip·macos
xixixin_2 小时前
【Vite】前端开发服务器的配置
服务器·前端·网络
.生产的驴2 小时前
Vue3 加快页面加载速度 使用CDN外部库的加载 提升页面打开速度 服务器分发
运维·服务器·前端·vue.js·分布式·前端框架·vue
史迪仔01122 小时前
Python生成器:高效处理大数据的秘密武器
前端·数据库·python
蓝婷儿3 小时前
前端面试每日三题 - Day 34
前端·面试·职场和发展