前言
在前端开发过程中,我们经常需要与后端进行数据交互,但在实际开发中,后端接口的开发进度可能会滞后,或者某些接口尚未完全实现,开发过程中简单的方式就是把想要的数据写死,但这样的坏处就是和后端联调前还需要再把写死的数据从代码里删除
什么是Mock数据
- Mock 数据是模拟的数据,用于模拟后端接口的返回结果
- 它可以在我们开发过程中替代真实的后端接口,进行前端页面的开发和调试
如何使用 Mock
- 本地模拟数据
- 浏览器拦截
node服务中转- 第三方工具集成
本地模拟数据
在方法里写死数据、请求后写死默认返回data
接口请求报错 404页面报错
浏览器拦截(xhr/fetch)
Better-mock
控制台此时就会输出数据了
better-mock 一个好处就是可以通过mockjs语法来生成一些随机的数据,每次请求都会返回不同的数据。
坏处是会在请求发送前就拦截,导致在 Chrome 控制台就看不见请求了
just mock
just mock 是一个浏览器插件,在我们代码中什么都不需要更改,只需要添加相应的接口和数据即可实现拦截。
不支持mockjs
node中转
koa
本地通过 koa 开启一个接口服务。
本地开启运行:node server.js,接口地址是 localhost:3003,但是请求的地址是 //localhost:9528 ,通过 webpack 的devServer配置,将请求转发到 localhost:3003
在控制台查看输出
同时Chrome 的 Network 可以看到发起的请求
思考: webpack项目中每次需要启动node服务???
webpack
webpack 也 devServer 启动了一个 HTTP 服务器,只不过用的不是 Koa ,是更早的一个框架 Express。
既然已经有了一个 HTTP 服务器,所以也没必要再开启另一个 Koa 的了,通过给 webpack 传递一个函数,重写 Koa 返回的数据即可
此时控制台也可以看到输出的内容
同时Chrome 的 Network 可以看到发起的请求
第三方工具集成
配置功能强大,接口管理与Mock 一体,可同步刷新后端接口,操作可视化,简单