现代化前端 Mock 数据的方案(MSW+faker.js)

前言

目前前端模拟数据除了通过一些接口调试工具来mock以外,偶尔使用express、nest之类,主要是用mock.js和better-mock,这两个本质是一个东西,后者是因为前者不维护而诞生出的一个分支,支持typescript。本文主要讲另外一种方式,就是通过msw和faker.js实现模拟。msw全称Mock Service Worker,是通过Worker实现的mock模拟前端接口返回。本方式相对来说比较新,也比较优雅。

基础配置

一、官网

MSW -- Seamless API mocking library for browser and Node | Mock Service Worker

二、安装

bash 复制代码
npm install msw --save-dev
# or
yarn add msw --dev

根据npm还是yarn包管理工具进行安装。

三、配置mock列表(./mock/handlers.js)

以下是我添加了单个的mock,实际上,你可以创建多个,方法是rest.post/get等..

req代表请求、res代表返回、ctx代表环境上下文(请求的一些数据)

javascript 复制代码
import { rest } from 'msw'


export const handlers = [
rest.post('/login', async (req, res, ctx) => {
    const { username } = await req.json()

    return res(
        ctx.status(200),
        ctx.delay(1000),
        ctx.json({
        username,
        firstName: 'John'
      })
    )
  }),]

通过ctx.status()可以设置接口返回状态码、通过ctx.delay()可以实现接口延迟,比如弱网测试

四、生成worker脚本

通过cli生成必要的依赖文件到public目录下。

javascript 复制代码
npx msw init <PUBLIC_DIR> --save

这里PUBLIC_DIR就是我们public文件夹的路径,Vite为public(绝大多数框架都是public)

javascript 复制代码
./public

所以,命令是

javascript 复制代码
npx msw init public/ --save

五、创建浏览器的worker

我们要测试是浏览器的环境,所以说需要创建一个浏览器worker:browser.js

javascript 复制代码
// src/mocks/browser.js
import { setupWorker } from 'msw'
import { handlers } from './handlers'

export const worker = setupWorker(...handlers)

六、引入main.js下进行挂载

javascript 复制代码
if (import.meta.env.MODE === 'development') {
  const { worker } = await import("./mock/browser");
  worker.start()
}

七、检查msw集成结果

控制台输出以下内容,代表msw启动成功

javascript 复制代码
[MSW] Mocking enabled

faker.js集成

一、安装依赖和导入

javascript 复制代码
npm install --save-dev @faker-js/faker


import { faker } from '@faker-js/faker';

二、使用简单的方法

javascript 复制代码
export const handlers = [
rest.post('/login', async (req, res, ctx) => {
    const { username } = await req.json()

    return res(
        ctx.status(200),
        ctx.delay(1000),
        ctx.json({
        username,
        firstName: faker.internet.userName()
      })
    )
  }),]

有关faker.js更多API请直接访问faker的git页面,查询。

相关推荐
浮游本尊9 分钟前
React 18.x 学习计划 - 第四天:React Hooks深入
前端·学习·react.js
future_studio30 分钟前
聊聊 Unity(小白专享、C# 小程序 之 日历、小闹钟)
前端·html
Yeats_Liao1 小时前
Go Web 编程快速入门 · 04 - 请求对象 Request:头、体与查询参数
前端·golang·iphone
立志成为大牛的小牛1 小时前
数据结构——二十六、邻接表(王道408)
开发语言·数据结构·c++·学习·程序人生
祈祷苍天赐我java之术1 小时前
Redis 数据类型与使用场景
java·开发语言·前端·redis·分布式·spring·bootstrap
MediaTea2 小时前
Python 第三方库:matplotlib(科学绘图与数据可视化)
开发语言·python·信息可视化·matplotlib
草莓熊Lotso2 小时前
C++ 方向 Web 自动化测试入门指南:从概念到 Selenium 实战
前端·c++·python·selenium
JS.Huang2 小时前
【JavaScript】原生函数
开发语言·javascript·ecmascript
Olrookie2 小时前
若依前后端分离版学习笔记(二十)——实现滑块验证码(vue3)
java·前端·笔记·后端·学习·vue·ruoyi
533_3 小时前
[vue] dayjs 显示实时时间
前端·javascript·vue.js