Mock.js

  在开发后端的应用中,我们使用postman来测试接口,观察和验证前后端之间的数据传递是否正常。

  在开发前端的应用中,我们使用Mock.js来模拟后端服务,以便进行前端业务逻辑的开发和测试。

  一般情况下,个人开发或者小团队开发是前后端分离的,各自完成后再集中组合测试,之前都是各自独立完成。虽然现在的开发者一般都是全栈(全端)的,但是提供一个完整的后端服务也不是一件容易的事情,建立与需求对应的数据库,然后使用开发工具进行开发,这些都需要时间。

  现在的前端请求基于Axios的居多,而mock.js刚好基于XMLHttpRequest,它就是对 XMLHttpRequest 对象进行了拦截和重写来实现的提供数据的功能,它可以有效地拦截Axios请求并返回开发者所需要的数据,在前端测试完成后,删除或者注释掉mock.js提供的服务,那么就可以与后端的服务无缝集成了。

  需要注意的是,如果是fetch请求的服务,那么mock.js并不能拦截,因为fetch并不基于XMLHttpRequest。(使用fetch-mock拦截)

  mock.js的官网地址:Mock.js

  一、在node中进行模拟
  ⑴新建一个目录;
  ⑵在该目录下安装mock.js;

npm install mockjs

  ⑶编写测试脚本并命名为test01.js;

//引入mock.js
const Mock=require("mockjs");
//创建模拟数据
const data=Mock.mock({
    'arr|1-5':[{
        'id|+1':1,
        'name':'@Cname',
        'SFZ':generateSFZ() 
    }]
})
//输出数据
//console.log(data);
//输出JSON格式的数据
console.log(JSON.stringify(data,null,4));

function generateSFZ() {
    // 生成随机的省、市、县代码
    const regionCode = Math.floor(Math.random() * 1000).toString().padStart(6, '0');
    
    // 生成随机的出生日期
    const birthDate = randomDate(new Date(1970, 0, 1), new Date());
    
    // 生成随机的4位数字
    const randomCode = Math.floor(Math.random() * 10000).toString().padStart(4, '0');
    
    // 拼接身份证号码
    const idNumber = regionCode + birthDate + randomCode;
    
    return idNumber;
}

// 生成指定范围内的随机日期
function randomDate(start, end) {
    return new Date(start.getTime() + Math.random() * (end.getTime() - start.getTime())).toISOString().slice(0, 10).replace(/-/g, '');
}

  ⑷运行获取返回的结果;

nodemon test01.js

  ⑸得到如下数据;

{
    "arr": [
        {
            "id": 1,
            "name": "吴磊",
            "SFZ": "000988197304198263"
        },
        {
            "id": 2,
            "name": "白秀兰",
            "SFZ": "000988197304198263"
        },
        {
            "id": 3,
            "name": "姚秀兰",
            "SFZ": "000988197304198263"
        },
        {
            "id": 4,
            "name": "胡霞",
            "SFZ": "000988197304198263"
        },
        {
            "id": 5,
            "name": "高刚",
            "SFZ": "000988197304198263"
        }
    ]
}


  二、在网页中进行模拟

  大多数情况下,我们都是在网页中进行模拟。在网页中实现的操作比较简单,在网页中加载mock.js(将mock.js下载到本地),然后就可以直接使用。
  网页代码:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8"></meta>
        <title>MockJS</title>
        <script src="mock.js"></script>
    </head>
<body>    
    <textarea id="MyOutput" rows="10" cols="20"></textarea>
    <button id="myButton">执行</button>
    <script>
            const data=Mock.mock({
                'arr|1-5':[{
                    'id|+1':1,
                    'name':'@Cname',
                    'SFZ':generateSFZ() 
                }]
            })

            function generateSFZ() {
                // 生成随机的省、市、县代码
                const regionCode = Math.floor(Math.random() * 1000).toString().padStart(6, '0');                
                // 生成随机的出生日期
                const birthDate = randomDate(new Date(1970, 0, 1), new Date());                
                // 生成随机的4位数字
                const randomCode = Math.floor(Math.random() * 10000).toString().padStart(4, '0');                
                // 拼接身份证号码
                const idNumber = regionCode + birthDate + randomCode;                
                return idNumber;
            }

            // 生成指定范围内的随机日期
            function randomDate(start, end) {
                return new Date(start.getTime() + Math.random() * (end.getTime() - start.getTime())).toISOString().slice(0, 10).replace(/-/g, '');
            }

        // 获取按钮和多行文本框的 DOM 元素
        const Mybutton = document.getElementById("myButton");
        const Myoutput = document.getElementById("MyOutput");
        // 给按钮添加点击事件监听器
        Mybutton.addEventListener("click", function() {
            //将结果输出到多行文本框中
            Myoutput.value = JSON.stringify(data,null,4);
        });
    </script>
</body>
</html>

  网页结果显示:

  三、注意

  1、拦截Axios请求,关键是请求地址的一致。

//Axios请求
axios.request({
	method:'get',
	url:"请求地址"
}).then(
	res=>{	console.log(res.data);	}
);

//mock拦截
Mock.mock('请求地址',{
	'data|5':[{
		'name':'@cname',
		'age':'@integer'
	}]
});

  2、Mock.js的语法规范包括数据模板定义和数据占位定义。
    数据模板定义:'属性名|生成规则':属性值。

  支持函数和正则表达式很有用,根据开发需求可以使用函数或者正则表达式来完成,很方便灵活。
  3、数据定义的占位符号@以及搭配,可以使用系统内置的名称来完成相应的数据定义,支持字符串的拼接。

  例如下面的代码:

const Mock=require("mockjs");
const data=Mock.mock({
    'arr|3':[{
        'id':"@id",
        'name':"@cname",
        'email':"@email",
        'address':"@region",
        'integer':"@integer",
        'color':"@color",
        'datetime':"@datetime",
        'title':"@ctitle",
        'ip':"@ip",
        'url':"@url",
    }]
})

  输出结果数据:

{
    "arr": [
        {
            "id": "130000199504118134",
            "name": "侯平",
            "email": "r.hosye@bpawnvjnn.sy",
            "address": "西北",
            "integer": 245581220630184,
            "color": "#f279a5",
            "datetime": "1987-04-09 05:16:52",
            "title": "技解马性石",
            "ip": "159.228.60.56",
            "url": "prospero://koimjk.bb/suwiijnm"
        },
        {
            "id": "34000020030915787X",
            "name": "汪军",
            "email": "b.tlkhrvmuu@htjgelx.gi",
            "address": "华东",
            "integer": 1558748183328488,
            "color": "#79c8f2",
            "datetime": "2017-01-17 04:17:01",
            "title": "正件做几二程",
            "ip": "134.237.192.134",
            "url": "cid://nounwtt.in/dppmbsr"
        },
        {
            "id": "450000200502184074",
            "name": "龙娜",
            "email": "j.uvvggjcr@ehnsid.sa",
            "address": "华北",
            "integer": 3322039815551336,
            "color": "#ebf279",
            "datetime": "2008-03-17 01:28:18",
            "title": "查标设民你题",
            "ip": "97.194.44.215",
            "url": "prospero://jbuxf.lc/qgrymgj"
        }
    ]
}

  4、带有图形界面的FastMock更简单和容易使用,地址:FastMock,可以根据个人情况下载使用。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Codeforces Round 919 (Div. 2)题解(A-E)

https://codeforces.com/contest/1920 A Satisfying Constraints 链接&#xff1a;A - Satisfying Constraints 代码 #include <bits/stdc.h> using namespace std; int main() {int T;cin >> T;while(T--){int n;scanf("%d", &n);vector<int&…

算法沉淀——BFS 解决 FloodFill 算法(leetcode真题剖析)

算法沉淀——BFS 解决 FloodFill 算法 01.图像渲染02.岛屿数量03.岛屿的最大面积04.被围绕的区域 BFS&#xff08;广度优先搜索&#xff09;解决 Flood Fill 算法的基本思想是通过从起始点开始&#xff0c;逐层向外扩展&#xff0c;访问所有与起始点相连且具有相同特性&#xf…

docker (三)-开箱即用常用命令

一 docker架构 拉取镜像仓库中的镜像到本地&#xff0c;镜像运行产生一个容器 registry 镜像仓库 registry可以理解为镜像仓库&#xff0c;用于保存docker image。 Docker Hub 是docker官方的镜像仓库&#xff0c;docker命令默认从docker hub中拉取镜像。我们也可以搭建自己…

【Windows】删除 VHD 虚拟磁盘时提示“文件已在 System 中打开”的解决方法

一、原因 正如显示的那样&#xff0c;虚拟磁盘仍在被系统占用。因此我们需要断开磁盘与系统的连接。 二、解决方法 1. 在“开始”菜单中搜索“磁盘管理”&#xff0c;选择“创建并格式化硬盘分区”。 2. 右键点击需要删除的虚拟磁盘&#xff0c;选择“分离 VHD”。 3. 点击“…

laravel_stub type-hints的简单介绍

开发者介绍 存根文件的类型提示的功能是由Nuno Maduro&#xff08;右边的人&#xff09;提供的。 stub type-hints 指的是在 stub 文件中使用的类型提示&#xff08;type hints&#xff09;。 类型提示是 PHP 7 引入的一个特性&#xff0c;允许你在函数、方法和类的上下文中指…

day14笔记(多态)

多态 自己写多态演示遇见两个问题 1.在类里写show方法时犹豫要不要写参数,其实不用写参数也可以获取到类的信息 public void show(){//括号里面写参数吗System.out.println(getName()", "getAge());} 2.在测试类里面写方法时,写了一个show方法带参数,其实这里应该是…

Spring Boot 笔记 017 创建接口_新增文章

1.1实体类增加校验注释 1.1.1 自定义校验 1.1.1.1 自定义注解 package com.geji.anno;import com.geji.validation.StateValidation; import jakarta.validation.Constraint; import jakarta.validation.Payload; import jakarta.validation.constraints.NotEmpty;import jav…

【Redis快速入门】Redis三种集群搭建配置(主从集群、哨兵集群、分片集群)

个人名片&#xff1a; &#x1f43c;作者简介&#xff1a;一名大三在校生&#xff0c;喜欢AI编程&#x1f38b; &#x1f43b;‍❄️个人主页&#x1f947;&#xff1a;落798. &#x1f43c;个人WeChat&#xff1a;hmmwx53 &#x1f54a;️系列专栏&#xff1a;&#x1f5bc;️…

Apache POI | Java操作Excel文件

目录 1、介绍 2、代码示例 2.1、将数据写入Excel文件 2.2、读取Excel文件中的数据 &#x1f343;作者介绍&#xff1a;双非本科大三网络工程专业在读&#xff0c;阿里云专家博主&#xff0c;专注于Java领域学习&#xff0c;擅长web应用开发、数据结构和算法&#xff0c;初步…

武器级工具包 Immunity Canvas 7.26安装使用体验

介绍&#xff1a; Immunity Canvas工具包有集成化、自动化、简单化的特点&#xff0c;大幅降低了攻击门槛。该工具是Immunity公司的一款商业级漏洞利用和渗透测试工具&#xff0c;包含了480多个以上的漏洞利用&#xff0c;该工具工具本来并不开源&#xff0c;但是在2021年Immu…

【PyQt】13-对话框

文章目录 前言一、知识储备二、详细展开2.1 通用对话框-QDialog2.1 消息类型对话框-QMessageBox运行结果 2.2 输入对话框 QInputDilog运行结果 2.3 字体对话框-QFontDialog运行结果 2.4 颜色对话框运行结果 2.5 文件对话框运行结果 总结 前言 1、四种形式的对话框。 2、警告框…

【从Python基础到深度学习】 8. VIM两种状态

一、安装 sudo apt install vim 二、VIM两种模式 - 命令状态/编辑状态 1.1 进入/退出VIM 进入VIM vim 退出vim :q <enter> 2.2 根目录下添加配置文件 window下创建vimrc类型文件内容如下&#xff1a; set nu set cursorline set hlsearch set tabstop4 使用Wins…

MySQL 基础知识(一)之数据库和 SQL 概述

目录 1 数据库相关概念 2 数据库的结构 ​3 SQL 概要 4 SQL 的基本书写规则 1 数据库相关概念 数据库是将大量的数据保存起来&#xff0c;通过计算机加工而成的可以进行高效访问的数据集合数据库管理系统&#xff08;DBMS&#xff09;是用来管理数据库的计算机系统&#xf…

QObject 的拷贝构造和赋值操作

QObject中没有提供一个拷贝构造函数和赋值操作符给外界使用&#xff0c;其实拷贝构造和赋值的操作都是已经声明了的&#xff0c;但是它们被使用了Q_DISABLE_COPY () 宏放在了private区域。因此所有继承自QObject的类都使用这个宏声明了他们的拷贝构造函数和赋值操作符为私有。 …

软件测试【四】Python复杂操作

一、Python中的数据类型:元组在python中的应用 在Python中&#xff0c;元组是一种不可变的数据类型&#xff0c;它和列表类似&#xff0c;但是元组创建后就不能被修改。元组使用小括号 () 来表示&#xff0c;其中的元素用逗号隔开。 元组在Python中的应用非常广泛&#xff0c…

Spring Boot 笔记 020 redis集成

1.1 安装redis Windows 下 Redis 安装与配置 教程_redis windows-CSDN博客 2.1 引入redis坐标 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency> 2.2 配置…

【前端高频面试题--Vue生命周期篇】

&#x1f680; 作者 &#xff1a;“码上有前” &#x1f680; 文章简介 &#xff1a;前端高频面试题 &#x1f680; 欢迎小伙伴们 点赞&#x1f44d;、收藏⭐、留言&#x1f4ac;前端高频面试题--Vue生命周期篇 往期精彩内容Vue的生命周期Vue子组件和父组件执行顺序在哪个生命周…

协调尺度:特征缩放在机器学习中的重要作用

目录 一、介绍 二、背景知识 三、了解功能缩放 四、特征缩放方法 五、特征缩放的重要性 六、实际意义 七、代码 八、结论 一、介绍 特征缩放是机器学习和数据分析预处理阶段的关键步骤&#xff0c;在优化各种算法的性能和效率方面起着至关重要的作用。本文深入探讨了特征缩放的…

【论文精读】DALL·E

摘要 本文利用从互联网上收集的2.5亿个图像/文本对数据&#xff0c;训练了一个120亿参数的自回归transformer&#xff0c;进而得到一个可以通过自然语言/图像控制生成的高保真图像生成模型。在大多数数据集上的表现超越以往的方法。 框架 本文的目标为通过训练一个自回归trans…