Mock.js介绍及使用总结
创始人
2024-05-29 07:22:57
0

1 什么是Mock.js

Mock.js用于生成随机的模拟数据,拦截 Ajax 请求,返回伪造的数据。因此在前端开发阶段就可以通过这个工具进行沉浸式开发,实现数据自产自销,降低和后端的沟通成本,实现真正意义上的前后端开发解耦合。相信我,使用这个工具,一定能够提高你的工作效率。

那么Mock.js有哪些特点呢?列举如下:

  1. 前后端分离:让前端攻城师独立于后端进行开发。
  2. 增加单元测试的真实性:通过随机数据,模拟各种场景。
  3. 开发无侵入:不需要修改既有代码,就可以拦截 Ajax 请求,返回模拟的响应数据。
  4. 用法简单:符合直觉的接口。
  5. 数据类型丰富:支持生成随机的文本、数字、布尔值、日期、邮箱、链接、图片、颜色等。
  6. 方便扩展:支持支持扩展更多数据类型,支持自定义函数和正则。

欲知更多,请见官网:Mock.js

2 怎么用

Mock的使用可以说是相当简单,安装好之后只需要动动手指,就能够让它运行起来了。

2.1 安装

npm install mockjs -D

2.2生成伪造的用户数据

这里以生成伪造的用户信息数据为例,简单介绍一下Mock.js是如何生成假数据的。定义UserType数据类型如下:

// UsrType.ts
type UserType = {uName: string,uId: string,uEmail: string,uAge: number
}export { UserType }

使用Mock生成伪造数据,将其封装成一个函数:

// user_mock.ts
import Mock from "mockjs";const getLoginRsp = () => Mock.mock({uName: Mock.Random.name(),uId: Mock.Random.id(),uAge: Mock.Random.natural(10, 50),uEmail: Mock.Random.email()
});export { getLoginRsp }

这里主要使用Mock.Random内置的方法生成了随机的用户名、用户ID、年龄和Email等数据,你还可以使用Mock生成更复杂的数据类型如数组,结构体、照片等等,更多示例请看官方示例,不再赘述。

既然已经定义好了这个伪造数据的函数,后续你想使用假数据,就可以直接调用getLoginRsp函数,即可得到假数据,举个栗子:

const mockData = getLoginRsp();
console.log(mockData);// uAge: 32
// uEmail: "d.topvut@bwwdcz.nt"
// uId: "630000198110044420"
// uName: "Nancy Hall"

是不是很方便?更方便的在后面!

2.3 拦截ajax请求,返回伪造数据

你可以使用Mock.mock()方法,将前端发送的ajax请求拦截,然后直接返回你想要的数据,前端开发大杀器!举个栗子,新建一个index.ts文件:

// mock/mock.ts
import Mock from "mockjs";
import { getLoginRsp } from "./auth_mock";// 拦截/api/login这个请求,请求类型为post,第三个参数就是你定义好的mock数据函数
Mock.mock("/api/login", 'post', getLoginRsp);

然后在项目入口处引入index.ts即可,我以React项目为例:

// main.ts
import React from 'react'
import ReactDOM from 'react-dom/client'
import App from './App'
import './index.css'// 在这里引入刚刚创建的index.ts文件
import "./mock/index"ReactDOM.createRoot(document.getElementById('root') as HTMLElement).render(,
)

接下来就是见证奇迹的时刻:我们在项目里面向/api/login接口请求数据:

// App.tsx
import axios from 'axios';
import { useEffect, useState } from 'react'
import './App.css'
import UserCard from './components/UserCard';
import { UserType } from './types/UserType';function App() {const [user, setUser] = useState();const updateUserCard = () => {axios.post("/api/login", {}).then(res => {setUser(res.data);});}useEffect(() => {setInterval(() => {updateUserCard();}, 2000);}, [])return (
user} />
); }export default App

UsrCard.tsx主要用于展示用户相应的数据:

import { UserType } from "../types/UserType";
import styles from "./UserCard.module.css";export default function UserCard({user}: {user: UserType | undefined}) {return 
styles.card}>

styles.title}>IDENTIFICATION CARD | 2023

styles.name}>{user?.uName || ""}

styles.id}>ID: {user?.uId || ""}

styles.age}>Age: {user?.uAge || ""}

styles.email}>Email: {user?.uEmail || ""}

}

最终呈现效果如下图所示:
在这里插入图片描述
成功获取到假数据,并且展示了出来!至此,使用Mock.js进行基本的数据伪造和请求拦截已经讲完了,更多复杂的用法,需要你结合自己的业务内容去探索了~

相关内容

热门资讯

诗词的由来? 诗词的由来?几年前?为啥来?诗歌概念起源 诗歌是一种主情的文学体裁,它以抒情的方式,高度凝练,集中地...
陈梦佳是好人吗? 陈梦佳是好人吗?我不了解TA
关于鹏的成语典故? 关于鹏的成语典故?据一个叫庄周的说这货在水里是鱼名鲲,上了天变成鸟叫鹏,纵横几千里,如垂天之云。据西...
上夜班很困怎么办, 上夜班很困怎么办, 白天多休息。注意饮食营养。晚上上班的时候可以听听节奏比较快的歌,或者听自己一向...
男生不主动找聊天就是没戏吧? 男生不主动找聊天就是没戏吧?你分情况,不同性格的人不一样。比如说处女男,因为天性原因希望女孩子主动一...
说人守时回家的成语 说人守时回家的成语 分秒必争 [fēn miǎo bì zhēng] 生词本基本释义一分一秒也一...
大航海探险物语要在什么辅助脚本... 大航海探险物语要在什么辅助脚本玩呢?大航海探险物语要在鸟人助手上玩呀,这款辅助脚本不用root一样可...
怎样锻炼孩子注意力集中? 怎样锻炼孩子注意力集中?第一,多训练孩子听力,在孩子听某些声音或语言,能听懂其中的细节和主旨。第二,...
本来可爱的小家伙,变成了难管教... 本来可爱的小家伙,变成了难管教的熊孩子,孩子太难管教了怎么办呢?多跟孩子沟通,走进孩子的内心,了解她...
孩子跳舞发圈简单句子 孩子跳舞发圈简单句子1、爸爸妈妈会为你在赛场上的努力而感到骄傲。我们爱你。2、感觉女儿特别的用心,在...
我女朋友和我说她只是喜欢我而不... 我女朋友和我说她只是喜欢我而不爱我,我还怎么办?就是因为你平时对她的宠爱,,让她变成了理所当然,,她...
关于通缉令的问题! 关于通缉令的问题!分级别的。A级才能公布大众的。如果你想曝光此事,可以找当地媒体。。。。
湖南涉外经济学院教师车祸造成 ... 湖南涉外经济学院教师车祸造成 2 人受伤,事故原因是什么?这是因为他们的心情不好的原因,所以,这样的...
微电影创作过程中,工作思路怎么... 微电影创作过程中,工作思路怎么写请问你说的是剧本创作还是拍摄工作,还是整个流程?
求类似异形大战铁血战士这样的把... 求类似异形大战铁血战士这样的把两部不同电影里的人物放到一起对打的电影弗莱迪大战杰森
喜欢看小说的进来 喜欢看小说的进来小说里面都有那些 剑法 轻功 剑名(倚天剑 )门派(专收女弟子的名字要好听的)风云也...
顾瑶周夜深小说叫什么名字? 顾瑶周夜深小说叫什么名字?不是冤家不成婚场景一:“贺尧谦你会有报应的!”某女手握拳头信誓旦旦。“放心...
永恒之塔各种达人(6种),前期... 永恒之塔各种达人(6种),前期中期后期分别做什么东西好卖?永恒之塔各种达人(6种),前期中期后期分别...
用精字组成不同的词语填空 用精字组成不同的词语填空节目( ) 制作( ) 装备( ) 包装( ) ( ...
什么是白富美?什么是高富帅? 什么是白富美?什么是高富帅?白富美就是长得白净、有钱、美丽漂亮,一般形容女的,高富帅是长得个子高,又...