如何在 Axios 中封装事件中心EventEmitter

梦应逍遥  金牌会员 | 2024-10-7 04:26:14 | 来自手机 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 530|帖子 530|积分 1590

在 Axios 中封装一个事件中心 EventEmitter 答应你在请求的差别阶段(如请求开始、请求乐成、请求失败等)触发事件。这可以通过创建一个自界说的 Axios 实例,并结合 Node.js 的 events 模块来实现。以下是一个具体的步调指南和示例代码,展示了如何在 Axios 中封装一个事件中心。
步调 1: 安装 Axios

首先,确保你已经安装了 Axios。如果还没有安装,可以使用 npm 或 yarn 进行安装:
  1. npm install axios
复制代码
或者
  1. yarn add axios
复制代码
步调 2: 创建事件中心类

接下来,创建一个新的类,该类将继续自 Node.js 的 EventEmitter 类,并封装 Axios 实例。
  1. const axios = require('axios');
  2. const EventEmitter = require('events');
  3. class AxiosEventEmitter extends EventEmitter {
  4.   constructor(baseURL = '') {
  5.     super();
  6.     this.axiosInstance = axios.create({
  7.       baseURL: baseURL,
  8.       // 可以在这里添加其他 Axios 配置
  9.     });
  10.     // 设置请求拦截器
  11.     this.axiosInstance.interceptors.request.use(
  12.       config => {
  13.         // 在请求发送前触发事件
  14.         this.emit('request-start', config);
  15.         return config;
  16.       },
  17.       error => {
  18.         // 请求错误时触发事件
  19.         this.emit('request-error', error);
  20.         return Promise.reject(error);
  21.       }
  22.     );
  23.     // 设置响应拦截器
  24.     this.axiosInstance.interceptors.response.use(
  25.       response => {
  26.         // 请求成功时触发事件
  27.         this.emit('response-success', response);
  28.         return response;
  29.       },
  30.       error => {
  31.         // 响应错误时触发事件
  32.         this.emit('response-error', error);
  33.         return Promise.reject(error);
  34.       }
  35.     );
  36.   }
  37.   // 封装 Axios 的请求方法
  38.   request(config) {
  39.     return this.axiosInstance(config);
  40.   }
  41.   get(url, params = {}, config = {}) {
  42.     return this.axiosInstance.get(url, { params, ...config });
  43.   }
  44.   post(url, data = {}, config = {}) {
  45.     return this.axiosInstance.post(url, data, config);
  46.   }
  47.   // 可以根据需要添加更多的封装方法,如 put, delete 等
  48. }
  49. module.exports = AxiosEventEmitter;
复制代码
步调 3: 使用封装的事件中心

现在,你可以在你的应用步伐中使用这个封装好的 AxiosEventEmitter 类。
  1. const AxiosEventEmitter = require('./path/to/AxiosEventEmitter');
  2. const emitter = new AxiosEventEmitter('https://api.example.com');
  3. // 监听事件
  4. emitter.on('request-start', config => {
  5.   console.log('Request started:', config.url);
  6. });
  7. emitter.on('response-success', response => {
  8.   console.log('Response succeeded:', response.data);
  9. });
  10. emitter.on('request-error', error => {
  11.   console.error('Request error:', error.message);
  12. });
  13. emitter.on('response-error', error => {
  14.   console.error('Response error:', error.response ? error.response.data : error.message);
  15. });
  16. // 发起一个 GET 请求
  17. emitter.get('/some-endpoint')
  18.   .then(response => {
  19.     // 处理响应
  20.   })
  21.   .catch(error => {
  22.     // 处理错误
  23.   });
复制代码
在这个示例中,AxiosEventEmitter 类封装了 Axios 实例,并添加了请求和响应拦截器来触发事件。然后,你可以在你的应用步伐中创建这个类的实例,并监听你感兴趣的事件。当请求开始时、乐成时、或遇到错误时,相应的事件监听器将被调用。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

梦应逍遥

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表