Mock.js生成随机数据,拦截 Ajax 请求

news2024/11/14 7:21:34

Mock.js 是一个用于模拟数据的 JavaScript 库,特别适合用于前端开发过程中生成假数据进行接口测试。它可以拦截 Ajax 请求并生成随机数据,还可以模拟服务器的响应来加速前端开发。

一、安装 Mock.js

可以通过以下几种方式引入 Mock.js

  1. CDN 引入

    <script src="https://cdn.jsdelivr.net/npm/mockjs/dist/mock.js"></script>
    
  2. 使用 npm

    npm install mockjs --save-dev
    

    在项目中引入:

    const Mock = require('mockjs');
    
  3. ES6 模块(在支持 ES6 模块的项目中):

    import Mock from 'mockjs';
    

二、基本用法

1. 定义模拟数据格式

Mock.js 提供了一个 Mock.mock 方法,使用 JSON 模板来定义数据结构:

Mock.mock(url, method, data)
  • url:要拦截的请求 URL,支持字符串或正则表达式。
  • method:请求类型,比如 "get""post",不区分大小写。
  • data:要返回的模拟数据格式。
示例:简单数据模拟
Mock.mock('/api/user', 'get', {
    'name': '@name',      // 随机生成名字
    'age|18-60': 1,       // 随机生成年龄,范围是 18 到 60
    'gender|1': ['male', 'female'], // 随机选取一个性别
});
  • @name 是 Mock.js 的占位符,会随机生成一个人名。
  • age|18-60 表示生成一个在 18 到 60 之间的随机整数。
  • gender|1 表示从数组中随机选取一个性别值。

/api/user 接口被请求时,Mock.js 会拦截这个请求并返回一个模拟的 JSON 对象,如:

{
    "name": "John Doe",
    "age": 35,
    "gender": "male"
}

三、Mock.js 数据模板语法

Mock.js 提供了丰富的数据模板语法来生成各种随机数据。以下是一些常用的占位符和规则:

1. 基础数据类型
  • name:随机生成一个人名(中文或英文)。

    'name': '@name'
    
  • string|1-10:生成 1 到 10 个字符组成的随机字符串。

    'string|1-10': '★'
    
  • boolean|1:生成随机布尔值(true 或 false)。

    'boolean|1': true
    
  • number|+1:生成递增数字,从初始值开始,每次调用增加 1。

    'id|+1': 1
    
2. 数组和对象
  • array|1-10:生成一个随机长度的数组。

    'items|1-10': [{
        'id|+1': 1,
        'name': '@name'
    }]
    
  • object|2:从对象中随机选取 2 个键值对。

    'object|2': {
        "name": "@name",
        "age|20-30": 25,
        "gender|1": ["male", "female"],
        "city": "New York"
    }
    
3. 日期和时间
  • date:生成随机日期,格式为 YYYY-MM-DD

    'date': '@date'
    
  • time:生成随机时间,格式为 HH:mm:ss

    'time': '@time'
    
  • datetime:生成随机日期和时间,格式为 YYYY-MM-DD HH:mm:ss

    'datetime': '@datetime'
    
4. 图片生成

Mock.js 还可以生成随机图片 URL,适用于生成假图片。

Mock.mock('/api/image', 'get', {
    'image': "@image('200x200', '#4A90E2', 'Hello')"
});
  • @image('200x200', '#4A90E2', 'Hello') 生成一个 200x200 大小的图片,背景颜色为 #4A90E2,文字为 Hello

四、拦截 AJAX 请求示例

以下是结合 axios 请求和 Mock.js 的示例。通过 Mock.js 拦截实际请求,返回模拟的数据:

import axios from 'axios';
import Mock from 'mockjs';

// 定义 Mock 数据
Mock.mock('/api/data', 'get', {
    'id|+1': 1,
    'title': '@title',
    'author': '@name',
    'content': '@paragraph',
    'publishDate': '@date'
});

// 发起请求,测试 Mock.js 返回的数据
axios.get('/api/data')
    .then(response => {
        console.log(response.data);
    })
    .catch(error => {
        console.error('Error:', error);
    });

每次调用时,/api/data 请求都会返回一个 JSON 对象,模拟一篇随机生成的文章信息。


五、正则匹配 URL

Mock.js 支持使用正则表达式匹配 URL,非常适合有动态参数的 API 请求。例如,匹配 /api/user/123 的请求:

Mock.mock(/\/api\/user\/\d+/, 'get', {
    'id': '@id',
    'name': '@name',
    'age|20-30': 1
});

此正则表达式 /\/api\/user\/\d+/ 会匹配 /api/user/ 后接任意数字的请求。


六、延迟响应

在真实环境中,网络请求通常会有延迟,可以用 Mock.setup 模拟响应时间:

Mock.setup({
    timeout: '300-800' // 300 到 800 毫秒之间的延迟
});

设置后,所有 Mock.js 拦截的请求都会随机延迟 300 至 800 毫秒后返回数据。


七、综合示例:模拟分页数据

以下是一个使用 Mock.js 模拟分页数据的示例:

Mock.mock(/\/api\/users\?page=\d+&pageSize=\d+/, 'get', (options) => {
    const url = new URL(`http://localhost${options.url}`);
    const page = parseInt(url.searchParams.get("page"));
    const pageSize = parseInt(url.searchParams.get("pageSize"));

    return Mock.mock({
        'total': 100,
        [`users|${pageSize}`]: [{
            'id|+1': (page - 1) * pageSize + 1,
            'name': '@name',
            'age|18-60': 1,
            'gender|1': ['male', 'female']
        }]
    });
});
  • 这个 Mock 拦截 /api/users?page=1&pageSize=10 形式的请求,返回 pageSize 条随机用户数据。
  • 每次请求会返回 10 条用户数据和 total 总数值为 100,可以模拟分页查询效果。

总结

  • 定义数据结构:通过 JSON 模板定义结构,并使用占位符生成随机数据。
  • 拦截请求:通过 Mock.mock 拦截指定的 URL 请求。
  • 自定义生成规则:通过 Mock.js 的占位符生成丰富的数据类型,包括字符串、数值、数组、日期、图片等。
  • 模拟延迟:使用 Mock.setup 模拟网络延迟。

这样,就能用 Mock.js 高效创建模拟 API 数据接口来测试前端页面。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2240011.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于Python+Django+Vue3+MySQL实现的前后端分类的商场车辆管理系统

项目名称&#xff1a;基于PythonDjangoVue3MySQL实现的前后端分离商场车辆管理系统 技术栈 开发工具&#xff1a;PyCharm、Visual Studio Code (VSCode)运行环境&#xff1a;Python 3.10、MySQL 8.0、Node.js 18技术框架&#xff1a;Django 5、Vue 3.4、Ant-Design-Vue 4.12 …

JAVA后端生成图片滑块验证码 springboot+js完整案例

前言 现在大部分网部都是图片滑块验证码&#xff0c;这个得要与后端联动起来才是确保接口安全性 通过我们系统在发送手机短息时都会选进行滑块验证&#xff0c;但是我们要保证发送短息接口的全安&#xff0c;具体路思如下 那么这个滑块的必须是与后端交互才能保证安全性&…

人工智能大比拼(3)

已知x-,y-6&#xff0c;且下述表达式的值与x的取值无关&#xff0c;求y -10x2y7xy 上述这个很简单的数学题&#xff0c;可是在各家AI之间出现了争议&#xff0c;本期我使用了四个AI&#xff1a;kimi&#xff0c;商量&#xff0c;文心一言&#xff0c;chatyy 先来看一下kimi的表…

SQLI LABS | Less-45 POST-Error Based-String-Stacked-Bilnd

关注这个靶场的其它相关笔记&#xff1a;SQLI LABS —— 靶场笔记合集-CSDN博客 0x01&#xff1a;过关流程 输入下面的链接进入靶场&#xff08;如果你的地址和我不一样&#xff0c;按照你本地的环境来&#xff09;&#xff1a; http://localhost/sqli-labs/Less-45/ 本关是堆…

sol机器人pump机器人如何实现盈利的?什么是Pump 扫链机器人?

什么是Pump 扫链机器人&#xff0c;它的盈利逻辑优化策略是什么&#xff1f; Pump 扫链机器人&#xff0c;通过智能化、自动化的买卖操作帮助投资者实现快速盈利。在此基础上&#xff0c;我们对该机器人的盈利逻辑进行了深度优化&#xff0c;涵盖了买入策略和止盈策略的各个方面…

MYSQL SQL优化总结【快速理解】

1、优化insert操作 批量插入&#xff0c;防止大量与数据库进行访问 手动控制事务&#xff0c;减少事务的频繁开启和提交。 主键顺序插入 2、优化主键 主键优化的点就是避免主键过长&#xff0c;因为如果有二级索引&#xff0c;叶子节点存储的数据时间上是主键&#xff0c;如果主…

深入计算机语言之C++:String的模拟实现

&#x1f511;&#x1f511;博客主页&#xff1a;阿客不是客 &#x1f353;&#x1f353;系列专栏&#xff1a;从C语言到C语言的渐深学习 欢迎来到泊舟小课堂 &#x1f618;博客制作不易欢迎各位&#x1f44d;点赞⭐收藏➕关注 一、模拟实现 string 库 1.1 string 的成员变量…

植物大战僵尸杂交版v2.6.1最新版本(附下载链接)

B站游戏作者潜艇伟伟迷于11月3日更新了植物大战僵尸杂交版2.6.1版本&#xff01;&#xff01;&#xff01;&#xff0c;有b站账户的记得要给作者三连关注一下呀&#xff01; 不多废话下载链接放上&#xff1a; 夸克网盘链接&#xff1a;https://pan.quark.cn/s/279e7ed9f878 新…

【Pikachu】目录遍历实战

既然已经决定做一件事&#xff0c;那么除了当初决定做这件事的我之外&#xff0c;没人可以叫我傻瓜。 1.目录遍历漏洞概述 目录遍历漏洞概述 在Web功能的设计过程中&#xff0c;开发者经常会将需要访问的文件作为变量进行定义&#xff0c;以实现前端功能的灵活性。当用户发起…

[ 网络安全介绍 5 ] 为什么要学习网络安全?

&#x1f36c; 博主介绍 &#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 _PowerShell &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 &#x1f389;点赞➕评论➕收藏 养成习…

项目技术栈-解决方案-注册中心

项目技术栈-解决方案-注册中心 Zookeeper、Eureka、Nacos、Consul和Etcd参考文章 服务注册中心&#xff08;Registry&#xff09;&#xff1a;用于保存 RPC Server 的注册信息&#xff0c;当 RPC Server 节点发生变更时&#xff0c;Registry 会同步变更&#xff0c;RPC Client …

除了 Postman,还有什么好用的 API 测试工具吗

尽管 Postman 提供了团队协作的功能&#xff0c;但是免费版本的功能较为基础&#xff0c;付费版的价格对于小型团队或个人开发者来说可能较高。而且访问 Postman 有时会非常慢&#xff0c;太影响体验了。 鉴于上述局限性&#xff0c;Apifox 成为了一个很好的替代选择。Apifox …

WPF学习之路,控件的只读、是否可以、是否可见属性控制

C#的控件学习之控件属性操作 控件的只读、是否可以、是否可见&#xff0c;是三个重要的参数&#xff0c;在很多表单、列表中都有用到&#xff0c;正常表单控制可以在父层主键控制参数是否可以编辑和可见&#xff0c;但是遇到个别字段需要单独控制时&#xff0c;可以在初始化wi…

LabVIEW开发相机与显微镜自动对焦功能

自动对焦是显微成像系统中的关键功能&#xff0c;通常由显微镜的电动调焦模块或特定的镜头系统提供&#xff0c;而工业相机则主要用于高分辨率图像的采集&#xff0c;不具备独立的自动对焦功能。以下是自动对焦的工作原理、实现方式及实际应用案例。 1. 自动对焦的工作原理 &a…

IBM 开源的文档转化利器「GitHub 热点速览」

上周的热门开源项目&#xff0c;Star 数增长犹如坐上了火箭&#xff0c;一飞冲天。短短一周就飙升了 6k Star 的多格式文档解析和导出神器 Docling&#xff0c;支持库和命令行的使用方式。全新的可视化爬虫平台 Maxun&#xff0c;则在刚开源时便轻松斩获了 4k Star。而本地优先…

STM32完全学习——点亮LED灯

一、寄存器描述 首先我们知道STM32对外设的操作&#xff0c;是靠对寄存器的设置来完成的。因此我们想要点亮LED灯&#xff0c;就需要知道端口的控制寄存器&#xff0c;然后给寄存器设置不同的值就可以让端口来输出0或1&#xff0c;首先我这里使用的是GPIOA这个端口的0-8位来做…

【MongoDB】MongoDB的核心-索引原理及索引优化、及查询聚合优化实战案例(超详细)

文章目录 一、数据库查询效率问题引出索引需求二、索引的基本原理及作用&#xff08;一&#xff09;索引的创建及数据组织&#xff08;二&#xff09;不同类型的索引&#xff08;三&#xff09;索引的额外属性 三、索引的优化与查询计划分析&#xff08;一&#xff09;通过prof…

约束(MYSQL)

not null&#xff08;非空&#xff09; unique&#xff08;唯一&#xff09; default&#xff08;默认约束&#xff0c;规定值&#xff09; 主键约束primary key&#xff08;非空且唯一&#xff09; auto_increment&#xff08;自增类型&#xff09; 复合主键 check&#xff08…

如何保证RabbitMQ的可靠性传输

文章目录 producer到broke生产者到交换机&#xff1a;confirm交换机到队列&#xff1a;returns模式队列溢出&#xff1a;可以采用死信等方式①ConfirmCallback接口②ReturnCallback接口 Broke内部Broke到达消费者 producer到broke 发送方确认 生产者到交换机&#xff1a;conf…

数据库参数备份

MySQL #!/bin/bash # 获取当前日期和时间的时间戳 TIMESTAMP$(date "%Y%m%d-%H%M%S")# 0、创建目录 mkdir /tmp/parameter_$TIMESTAMP/# 1、获取所有命名空间 echo "1、获取所有命名空间" NAMESPACES$(kubectl get ns | grep qfusion- | grep -v qfusion-…