ReactJS 教程

ReactJS - 主页 ReactJS - 简介 ReactJS - 路线图 ReactJS - 安装 ReactJS - 功能 ReactJS - 优势和缺点 ReactJS - 架构 ReactJS - 创建 React 应用程序 ReactJS - JSX ReactJS - 组件 ReactJS - 嵌套组件 ReactJS - 使用组件 ReactJS - 集合组件 ReactJS - 样式 ReactJS - 属性 (props) ReactJS - 使用属性创建组件 ReactJS - props 验证 ReactJS - 构造函数 ReactJS - 组件生命周期 ReactJS - 事件管理 ReactJS - 创建事件感知组件 ReactJS - Expense Manager 事件 ReactJS - 状态管理 ReactJS - 状态管理 API ReactJS - 无状态组件 ReactJS - Hooks 进行状态管理 ReactJS - Hooks 的组件生命周期 ReactJS - 布局组件 ReactJS - 分页 ReactJS - Material UI ReactJS - Http 客户端编程 ReactJS - 表单编程 ReactJS - 受控组件 ReactJS - 非受控组件 ReactJS - Formik ReactJS - 条件渲染 ReactJS - 列表 ReactJS - Key 键 ReactJS - 路由 ReactJS - Redux ReactJS - 动画 ReactJS - Bootstrap ReactJS - Map ReactJS - 表格 ReactJS - 使用 Flux 管理状态 ReactJS - 测试 ReactJS - CLI 命令 ReactJS - 构建和部署 ReactJS - 示例

Hooks

ReactJS - Hooks 简介 ReactJS - 使用 useState ReactJS - 使用 useEffect ReactJS - 使用 useContext ReactJS - 使用 useRef ReactJS - 使用 useReducer ReactJS - 使用 useCallback ReactJS - 使用 useMemo ReactJS - 自定义 Hooks

ReactJS 高级

ReactJS - 可访问性 ReactJS - 代码拆分 ReactJS - 上下文 ReactJS - 错误边界 ReactJS - 转发 Refs ReactJS - 片段 ReactJS - 高阶组件 ReactJS - 与其他库集成 ReactJS - 优化性能 ReactJS - Profiler API ReactJS - Portals ReactJS - 不使用 ES6 ECMAScript ReactJS - 不使用 JSX 的 React ReactJS - Reconciliation ReactJS - Refs 和 DOM ReactJS - 渲染道具 ReactJS - 静态类型检查 ReactJS - 严格模式 ReactJS - Web 组件

其他概念

ReactJS - 日期选择器 ReactJS - Helmet ReactJS - 内联样式 ReactJS - PropTypes ReactJS - BrowserRouter ReactJS - DOM ReactJS - 轮播 ReactJS - 图标 ReactJS - 表单组件 ReactJS - 参考 API

ReactJS 有用资源

ReactJS - 快速指南 ReactJS - 备忘录 Axios - 备忘录 ReactJS - 有用资源 ReactJS - 讨论


Axios 备忘录

Axios 备忘录 基于 Axios,并使用这个广受欢迎的 HTTP 客户端以 JavaScript 发出 API 请求。它描述了如何安装 Axios 和执行 CRUD 操作,还具有请求拦截器、授权标头和重试逻辑等高级功能。您还将了解如何设置全局配置、管理错误、转换请求和响应以及同时发出请求。有关安全、动态和模块化 API 集成的最佳实践的更多详细信息,请查看文档本身。

目录

简介

Axios. js 是一个轻量级 JavaScript 库,用于从浏览器或 Node. js 发出 HTTP 请求。它通过提供易于使用的基于承诺的语法来执行 GET、POST、PUT、DELETE 和其他 HTTP 方法,从而加快 API 交互。 Axios 评论经常称赞它对 JSON 数据的简单处理、易于管理的请求和响应拦截器以及高效的错误处理。

安装和基础知识

使用 npm 安装 Axios

npm install axios

基本

import axios from 'axios';
const instance = axios.create({
   baseURL: 'https://api.example.com',
   timeout: 1000,
   headers: { 'Authorization': 'Bearer token' }
});

使用 Axios 进行 CRUD 操作

GET 请求

从 API 端点获取数据

axios.get('https://reqres.in/api/users?delay=2')
.then(response => {
   console.log(response.data);
})
.catch(error => {
   console.log("This is error: " + error.response);
})
.finally(() => {
   // 始终执行
});

POST 请求

将数据发送到 API 端点

axios.post('https://reqres.in/api/users', {
   "name": "aman",
   "job": "it"
})
.then(response => {
   console.log(response.data);
})
.catch(error => {
   console.log(error.response);
})
.finally(() => {
   // 始终执行
});

PUT 请求

更新 API 端点上的现有数据。

axios.put('https://reqres.in/api/users/2', {
   "name": "Raju",
   "job": "Dev Ops"
})
.then(response => {
   console.log(response.data);
})
.catch(error => {
   console.log(error.response);
})
.finally(() => {
   // 始终执行
});

DELETE 请求

从 API 端点删除数据。

axios.delete('https://reqres.in/api/users?page=2')
.then(response => {
   console.log(response.data);
})
.catch(error => {
   console.log(error.response);
})
.finally(() => {
   // 始终执行
});

带有授权标头的请求

发送带有授权令牌的请求。

axios.post('https://reqres.in/api/users', {
   "data": "somedata"
}, {
   headers: { 'Authorization': 'Token' }
})
.then(response => {
   console.log(response.data);
})
.catch(error => {
   console.log(error.response);
})
.finally(() => {
   // 始终执行
});

高级 Axios 功能

基本 URL 配置

设置基本 URL 以获得更简洁的代码。

axios.defaults.baseURL = 'https://api.example.com';

处理响应和错误

处理成功和错误响应。

axios.get('/endpoint')
.then(response => {
   console.log(response.data);
})
.catch(error => {
   console.error("Error: ", error.message);
});

请求和响应拦截器

全局修改请求和响应。

// 添加请求 
axios.interceptors.request.use(config => {
   config.headers['Authorization'] = 'Bearer token';
   return config;
}, error => Promise.reject(error));

// 添加响应
axios.interceptors.response.use(response => response, error => {
   console.error("Global error: ", error.response);
   return Promise.reject(error);
});

自定义 Axios 实例

使用特定配置创建可重复使用的实例。

const apiClient = axios.create({
   baseURL: 'https://api.example.com',
   timeout: 2000
});

重试逻辑

使用 axios-retry 实现自动重试。

import axiosRetry from 'axios-retry';

axiosRetry(axios, { retries: 3 });

进度跟踪

监控文件上传/下载进度。

axios.post('/upload', formData, {
   onUploadProgress: progressEvent => {
      console.log(`Uploaded: ${(progressEvent.loaded / progressEvent.total) * 100}%`);
   }
});

Request 请求取消

使用 CancelToken 或 AbortController 取消正在进行的请求。

const controller = new AbortController();

axios.get('/endpoint', { signal: controller.signal })
.catch(error => {
   if (error.name === 'CanceledError') {
      console.log('Request canceled');
   }
});

// 取消请求
controller.abort();

timeout 超时

设置请求超时。

axios.get('/endpoint', { timeout: 5000 })
.catch(error => {
   if (error.code === 'ECONNABORTED') {
      console.error('Request timed out');
   }
});

查询参数

在请求中传递查询字符串。

axios.get('/endpoint', {
   params: { id: 123, sort: 'desc' }
});

标头和授权

授权标头

axios.get('/user', {
   headers: { 'Authorization': 'Bearer YOUR_TOKEN' }
})
   .then(response => console.log(response.data))
   .catch(error => console.error(error));

自定义标题

axios.post('/submit', data, {
   headers: { 'Custom-Header': 'value' }
})
   .then(response => console.log(response.data))
   .catch(error => console.error(error));

处理全局配置

设置全局基本 URL −

axios.defaults.baseURL = 'https://api.example.com';

设置全局标头

axios.defaults.headers.common['Authorization'] = 'Bearer YOUR_TOKEN';

转换请求和响应

转换请求

axios.defaults.transformRequest = [(data) => {
   // 修改 request 请求数据
   return JSON.stringify(data);
}];

转换响应

axios.defaults.transformResponse = [(data) => {
   // 修改 Response 响应数据
   return JSON.parse(data);
}];

同时处理多个请求

axios.all([
   axios.get('/user'),
   axios.get('/posts')
])
.then(axios.spread((userResponse, postsResponse) => {
   console.log(userResponse.data);
   console.log(postsResponse.data);
}))
.catch(error => console.error(error));

全局处理错误

axios.interceptors.response.use(
   response => response,
   error => {
      if (error.response.status === 401) {
         console.log("Unauthorized: Redirecting to login...");
         // 重定向或处理刷新令牌逻辑
      } else if (error.response.status === 500) {
         console.log("Server error, please try again later.");
      }
      return Promise.reject(error);
   }
);