news 2026/4/17 17:52:25

后端:没空,先自己 mock 去!

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
后端:没空,先自己 mock 去!

前言

后端开发忙,不给你接口?

后端抱怨你在测试过程中,频繁的给脏数据?

后端修个接口很慢没法测试?

有了 mockjs ,这些问题将迎刃而解。不要 998,pnpm i 带回家!

真这么丝滑?

请看我的使用方式:

当后端接口无法满足要求,且不能及时更改时。例如后端返回

{ "err_no": 0, "err_msg": "success", "data": [ { "comment_id": "7337487924836287242", "user_info": { "user_name": "陈陈陈_", } } ], }

但我此时希望增加一个user_type来确定页面的展示。

那我就直接起一个文件:user.js,把刚才的响应 copy 过来,并追加改动

myMock('/api/v1/user', 'post', () => { return { "err_no": 0, "err_msg": "success", "data": [ { "comment_id": "7337487924836287242", "user_info": { "user_name": "陈陈陈_", "user_type": "admin", } } ], } });

如此一来,这个请求就被无缝替换为了我们的 mock,可以随便测试了。

机-会

技术大厂,前端-后端-测试,新一线和一二线城市等地均有机-会,感兴趣可以试试。待遇和稳定性都不错~

如何接入 mockjs

有的同学就要问了,主播主播,你的 mockjs 确实很方便,怎么接入比较好呀。别急,我们一步一步来

1、安装 mockjs

pnpm i mockjs

如果是使用 ts 的同学,可能需要额外安装 type 类型包:@types/mockjs

2、新建一个 mock 文件夹,在 mock/index.ts 放入基本路径

// 各种 mock 的文件,视条件而定,我这里有俩文件就引入了俩 import './login/user.js'; import './model/model.js';

并且在你的项目入口 ts 中引入 mock/index.ts

import './mock/index'; // 引入 mock 配置

3、导出一个 myMock 方法,并追加一个 baseUrl 方便直接联动你的 axios

import { ENV_TEST } from '@/api/config/interceptor'; import Mock from 'mockjs'; export const myMock = ( path: string, method: 'get' | 'post', callback: (options: any) => any ) => { Mock.mock(`${ENV_TEST}${path}`, method, callback); };

如此一来,你就可以在 mock 文件夹下去搞了,比如:

我想新增一个服务模块的各类接口的 mock,那么我就新增一个 service 文件夹,在其下增加一个 index.ts,并对对应路径进行 mock

myMock('/api/v1/service', 'get', () => { return { code: 0, msg: 'hello service', data: null, }; });

另外,别忘了在 mock/index.ts 引入文件

不显示在 network 中?

需要说明的是,这样走 mock 是不会触发真正的请求的,相当于 xhr 直接被 mock 拦截了下来并给了你返回值。所以你无法在 network 中看到你的请求。

这是个痛点,目前比较好的解决方案还是起一个单独的服务来 mock。但这样也就意味着,需要另起一个项目来单独做 mock,太不优雅了。

有没有什么办法,既可以走上述简单的mock,又可以在需要的时候起一个服务来查看 network,并且不需要额外维护两套配置呢?

有的兄弟,有的。

import express from 'express'; import bodyParser from 'body-parser'; import Mock from 'mockjs'; import './login/user.js'; import './model/model.js'; import { ENV_TEST } from './utils/index.js'; const app = express(); const port = 3010; // 使用中间件处理请求体和CORS app.use(bodyParser.json()); // 设置CORS头部 app.use(( _ , res, next) => { res.header('Access-Control-Allow-Origin', '*'); res.header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS'); res.header('Access-Control-Allow-Headers', 'Content-Type, Authorization'); next(); }); // 设置Mock路由的函数 const setupMockRoutes = () => { const mockApis = Mock._mocked || {}; // 遍历每个Mock API,并生成对应的路由 Object.keys(mockApis).forEach((key) => { const { rurl, rtype, template } = mockApis[key]; const route = rurl.replace(ENV_TEST, ''); // 去掉环境前缀 // 根据请求类型(GET, POST, 等)设置路由 app[rtype.toLowerCase()](route, (req, res) => { const data = typeof template === 'function' ? template(req.body || {}) : template; res.json(Mock.mock(data)); // 返回模拟数据 }); }); }; // 设置Mock API路由 setupMockRoutes(); // 启动服务器 app.listen(port, () => { process.env.NODE_ENV = 'mock'; // 设置环境变量 console.log(`Mock 服务已启动,访问地址: http://localhost:${port}`); });

直接在 mock 文件夹下追加这个启动文件,当你需要看 network 的时候,将环境切换为 mock 环境即可。本质是利用了Mock._mocked可以拿到所有注册项,并用 express 起了一个后端服务响应这些注册项来实现的。

在拥有了这个能力的基础上,我们就可以调整我们的命令

"scripts": { "dev": "cross-env NODE_ENV=test vite", "mock": "cross-env NODE_ENV=mock vite & node ./src/mock/app.js" },

顺便贴一下我的 env 配置:

export const ENV_TEST = 'https://api-ai.com/fuxi'; export const ENV_MOCK = 'http://localhost:3010/'; let baseURL: string = ENV_TEST; console.log('目前环境为:' + process.env.NODE_ENV); switch (process.env.NODE_ENV) { case 'mock': baseURL = ENV_MOCK; break; case 'test': baseURL = ENV_TEST; break; case 'production': break; default: baseURL = ENV_TEST; break; } export { baseURL };

这样一来,如果你需要看 network ,就 pnpm mock,如果不需要,就直接 pnpm dev,完全不需要其他心智负担。

三个字:

——转载自:imoo

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 3:33:37

12.18 中后台项目-权限管理

![[1280X1280 (46).PNG]] ![[1280X1280 (48).PNG]] ![[1280X1280 (50).PNG]] 权限管理总结 ![[download_image.jpeg]] 模拟路由信息数据 adminRouter.json [{"path": "/dashboard","component": "/layout/index.vue","title"…

作者头像 李华
网站建设 2026/4/17 4:20:13

2025届计算机专业大学生,敢问路在何方?

目录 互联网裁员 计算机专业本科生就业情况 计算机专业转角遇到爱 网络安全行业特点 如何入门学习网络安全 零基础入门 互联网裁员 这两天,关于大厂,特别是互联网大厂裁员、优化员工的新闻再次受到关注。 从裁员情况看,谷歌、亚马逊…

作者头像 李华
网站建设 2026/4/16 12:48:24

计算机科学与技术,软件工程,网络空间安全这三个专业考研怎么选?

前言 三个专业本质上都是万金油专业。三个专业间本身都可以横跳找工作。只是人事部可能会关心招人要求里会有点要求,这也是写个人学历或工作简历问题。除了专项课题研发外,几乎没有什么差别。 只能根据你的未来工作打算来规划 1)考研后继续…

作者头像 李华
网站建设 2026/4/16 12:48:26

SmokeAPI终极指南:完全解锁Steam游戏DLC的免费方案

SmokeAPI终极指南:完全解锁Steam游戏DLC的免费方案 【免费下载链接】SmokeAPI Legit DLC Unlocker for Steamworks 项目地址: https://gitcode.com/gh_mirrors/smo/SmokeAPI 还在为Steam游戏的高价DLC发愁吗?想要体验完整游戏内容却不想掏空钱包&…

作者头像 李华
网站建设 2026/4/16 12:48:25

2026年如何成功入行网络安全?这份精准学习与择业指南请收好

在2026年,随着科技的飞速发展,人类社会已经全面迈入了数字化时代。万物互联、人工智能、大数据、云计算等前沿技术正以前所未有的速度改变着我们的生活和工作方式。然而,正如硬币的两面,这一数字化的浪潮也带来了前所未有的网络安…

作者头像 李华
网站建设 2026/4/17 17:14:19

2026网安入行指南:如何抓住行业东风,成为企业争抢的新兴赛道人才?

2026年网络安全行业的前景看起来非常乐观。根据当前的趋势和发展,一些趋势和发展可能对2025年网络安全行业产生影响: 5G技术的广泛应用:5G技术的普及将会使互联网的速度更快,同时也将带来更多的网络威胁和安全挑战。网络安全专家…

作者头像 李华