前端mock数据那些事

前言

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

什么是Mock数据

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

如何使用 Mock

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

本地模拟数据

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

image.png

image.png

接口请求报错 404 页面报错

浏览器拦截(xhr/fetch

Better-mock

image.png

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

image.png

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

image.png

just mock

just-mock.vercel.app/

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

image.png

image.png

image.png

node中转

koa

mockjs官网

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

image.png

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

image.png

在控制台查看输出

image.png

同时Chrome 的 Network 可以看到发起的请求

image.png

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

webpack

webpack 也 devServer 启动了一个 HTTP 服务器,只不过用的不是 Koa ,是更早的一个框架 Express
既然已经有了一个 HTTP 服务器,所以也没必要再开启另一个 Koa 的了,通过给 webpack 传递一个函数,重写 Koa 返回的数据即可

image.png

此时控制台也可以看到输出的内容

image.png

同时Chrome 的 Network 可以看到发起的请求

image.png

第三方工具集成

配置功能强大,接口管理与Mock 一体,可同步刷新后端接口,操作可视化,简单

© 版权声明
THE END
喜欢就支持一下吧
点赞0

Warning: mysqli_query(): (HY000/3): Error writing file '/tmp/MYW0wiIt' (Errcode: 28 - No space left on device) in /www/wwwroot/583.cn/wp-includes/class-wpdb.php on line 2345
admin的头像-五八三
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

图形验证码
取消
昵称代码图片