聊一聊前端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服务???

相关推荐
anOnion3 小时前
构建无障碍组件之Menu Button pattern
前端·html·交互设计
用户47949283569153 小时前
claude Fable用不了?把Gpt 5.5pro接到你的claude code里
前端·后端
zhangxingchao5 小时前
Kotlin常用的Flow 操作符整理
前端
IT_陈寒7 小时前
React的useState居然还有这种坑?我差点删库跑路
前端·人工智能·后端
Pedantic8 小时前
SwiftUI 手势笔记
前端·后端
橙子家9 小时前
浏览器缓存之【结构化数据库与缓存】: IndexedDB、Cache storage 和 Storage buckets
前端
user20585561518139 小时前
X6 中边悬浮置顶,规避 `mouseleave` 事件丢失问题
前端
李明卫杭州9 小时前
CSS aspect-ratio 属性完全指南
前端
Pedantic11 小时前
SwiftUI 手势层级(Gesture Hierarchy)详解
前端