当前位置: 首页 > news >正文

axios-mock-adapter使用

文章目录

  • 1. 安装 axios-mock-adapter
  • 2. 引入所需的库
  • 3. 创建一个模拟适配器实例
  • 4. 定义模拟响应
  • 5. 在你的代码中使用 axios
  • 6. 在测试或开发完成后清理模拟

axios-mock-adapter 是一个用于模拟 axios HTTP 请求的库。它允许你在测试或开发过程中,为 axios 实例提供模拟的响应,以便在没有实际后端服务的情况下进行前端功能的开发和测试。

1. 安装 axios-mock-adapter

首先,你需要安装 axios-mock-adapter。你可以使用 npm 或 yarn 来安装它:

注意:安装到开发环境!不要直接默认安装到

npm install axios-mock-adapter --save-dev  
# 或者  
yarn add axios-mock-adapter --dev

2. 引入所需的库

在你的测试文件或需要模拟请求的文件中,引入 axiosaxios-mock-adapter

import axios from 'axios';  
import MockAdapter from 'axios-mock-adapter';

3. 创建一个模拟适配器实例

接下来,你需要创建一个 MockAdapter 实例,并将其与你的 axios 实例关联起来:

// 创建axios实例
const service = axios.create({// axios中请求配置有baseURL选项,表示请求URL公共部分baseURL: import.meta.env.VITE_APP_BASE_API,// 超时timeout: 10000
})// 创建一个 MockAdapter 实例,并将其与你的 axios 实例关联起来
const mock = new MockAdapter(service);

4. 定义模拟响应

使用 mock 实例的 onGetonPostonPutonDelete 等方法来定义针对不同 HTTP 方法的模拟响应:

mock.onGet('/api/users').reply(200, {  users: [  { id: 1, name: 'John Doe' },  { id: 2, name: 'Jane Doe' }  ]  
});  mock.onPost('/api/users').reply(function (config) {  // 你可以访问请求的 config 对象,包括请求头和请求体  const { data } = config;  return [201, { id: data.id, name: data.name }]; // 返回状态码和响应数据  
});

建议使用单独一个mock文件夹,导入的形式来引入

// mock.js
export const MockGets = {'/captchaImage': {"msg": "操作成功","code": 200,"captchaEnabled": true,"uuid": "352f4bb7088d435dad641c34aad337c4"}
}// service.js
Object.keys(MockGets).forEach(function(key) {mock.onGet(key).reply(200, MockGets[key]);console.log(key + ": " + MockGets[key]);
});

5. 在你的代码中使用 axios

axios.get('/api/users')  .then(response => {  console.log(response.data); // 输出模拟的用户列表  })  .catch(error => {  console.error(error);  });

6. 在测试或开发完成后清理模拟

当你完成测试或开发,并希望使用真实的后端服务时,你需要确保移除或禁用所有的模拟。这通常是通过销毁 MockAdapter 实例或移除模拟定义来完成的。

mock.restore(); // 恢复所有模拟,使得 axios 请求将再次发往实际服务器
http://www.lryc.cn/news/334628.html

相关文章:

  • 基于单片机的家用无线火灾报警系统设计
  • LangChain:索引(Indexes)--基础知识
  • Cortex-M4架构
  • 对称排序(蓝桥杯)
  • React - 你使用过高阶组件吗
  • 【C语言】结构体、枚举、联合(自定义类型)
  • 用vue.js写案例——ToDoList待办事项 (步骤和全码解析)
  • 提高大型语言模型 (LLM) 性能的四种数据清理技术
  • Rust 练手小项目:猜数游戏
  • 蓝桥杯物联网竞赛_STM32L071_16_EEPROM
  • 复习知识点整理
  • 7款公司电脑监控软件
  • 服务器 安装1Panel服务器运维管理面板
  • 最大花之能量(蓝桥杯)
  • 探索算力(云计算、人工智能、边缘计算等):数字时代的引擎
  • 数据可视化-ECharts Html项目实战(10)
  • 甲方安全建设之研发安全-SCA
  • [html]网页结构以及常见标签用法
  • 【C语言】if语句选择题
  • ZLMediaKit ubantu 下编译
  • 什么是stable diffusion
  • C++ list链表模拟实现
  • LangChain - PromptTemplate
  • spring cloud gateway openfeign 联合使用产生死锁问题
  • 【WPF应用37】WPF基本控件-DatePicker的详解与示例
  • GitHub教程:最新如何从GitHub上下载文件(下载单个文件或者下载整个项目文件)之详细步骤讲解(图文教程)
  • 编译Nginx配置QUIC/HTTP3.0
  • 【JavaWeb】Day38.MySQL概述——数据库设计-DQL
  • 如何使用Java和RabbitMQ实现延迟队列(方式二)?
  • String.valueOf() 将各种数据类型的值转换为它们的字符串