聊一聊前端mock数据那些事

前言

在前端开发过程中,我们经常需要与后端进行数据交互,但在实际开发中,后端接口的开发进度可能会滞后,或者某些接口尚未完全实现,开发过程中简单的方式就是把想要的数据写死,但这样的坏处就是和后端联调前还需要再把写死的数据从代码里删除

关于Mock

什么是Mock数据

  • Mock 数据是模拟的数据,用于模拟后端接口的返回结果
  • 它可以在我们开发过程中替代真实的后端接口,进行前端页面的开发和调试

如何使用 Mock

  • 本地模拟数据
  • 浏览器拦截
  • node服务中转
  • 第三方工具集成

本地模拟数据

在方法里写死数据、请求后写死默认返回data

接口请求报错 404 页面报错

浏览器拦截(xhr/fetch

Better-mock

控制台此时就会输出数据了

better-mock 一个好处就是可以通过mockjs语法来生成一些随机的数据,每次请求都会返回不同的数据。 坏处是会在请求发送前就拦截,导致在 Chrome 控制台就看不见请求了

just mock

just-mock.vercel.app/

just mock 是一个浏览器插件,在我们代码中什么都不需要更改,只需要添加相应的接口和数据即可实现拦截。 不支持mockjs

node中转

mockjs官网

本地通过 koa 开启一个接口服务。

本地开启运行:node server.js,接口地址是 localhost:3003,但是请求的地址是 //localhost:9528 ,通过 webpack 的devServer配置,将请求转发到 localhost:3003

在控制台查看输出

同时ChromeNetwork 可以看到发起的请求

思考: webpack项目中每次需要启动node服务???

相关推荐
用户40269244819081 小时前
CRMEB Pro 新增后台接口全链路:路由、权限、验证器、返回格式一次讲清
前端·后端
泉城老铁1 小时前
springboot+vue+ ffmpeg 实现视频的拉流播放
前端
PedroQue992 小时前
uni-router v1.8.0新增冷启动守卫补执行
前端·uni-app
xiaok2 小时前
部署之后,本地浏览器还在读取旧缓存导致页面一直显示loading中
前端
用户059540174462 小时前
Redis缓存一致性踩坑实录:线上故障排查6小时,我用pytest+内存快照把它永久关进了笼子
前端·css
星栈2 小时前
我用 Rust + Dioxus 做了个全栈跨平台笔记应用:第一版先把列表和详情跑通
前端·rust·前端框架
用户1733598075372 小时前
Vue 3 SPA 首屏优化:从 3s 到 1.2s 的 5 个实践
前端·vue.js
咖啡无伴侣2 小时前
基础骨架:30 分钟搭好 pnpm workspace,完成双项目 Monorepo 迁入
前端
谷无姜2 小时前
Webpack5 进阶思考:那些官方文档没讲清楚的事
前端·webpack
weedsfly2 小时前
还在用 Axios?你可能需要重新理解 XHR 与 Fetch
前端·javascript·面试