JAVA基础--Mockjs

mock模拟动态数据

1.1. mockjs介绍

引入:刚刚的数据写死的,数据是不应该写死的。真实情况是我们应该发请求到后端去拿数据的。但是现在是前后端并行开发,现在还没有后端,只有接口的描述。所以前端要去模拟假数据来进行测试

Mock.js (官网Mock.js)是一款数据模拟生成器,旨在帮助前端攻城师独立于后端进行开发,模拟假数据进行测试

1.2. mockjs作用
1. 根据数据模板生成模拟数据
2. 模拟后端接口,响应数据
1.3. 快速入门
1.3.1. 安装mockjs
npm install mockjs
1.3.2. 新建mockDemo.js
//引入mockjs
let Mock=require('mockjs')
let data=Mock.mock({//规则:值'list|5':[{'id':1,'name':'测试'}]
})
console.log(JSON.stringify(data))
1.3.3. 测试
node mockDemo.js
1.3.4. 其他规则
//引入mockjs
let Mock=require('mockjs')
let data=Mock.mock({//规则:值'list|5':[{'id': '@increment','name': '@cname','phone': /^1[0-9]{10}$/,'email': '@email','address': '@county(true)','createTime': '@date("yyyy-MM-dd")'}]
})
console.log(JSON.stringify(data))

2. mock模拟接口

引入:虽然数据出来了,但是数据应该是通过请求调用而产生的

2.1. 接口文件user.js
//import Mock from 'mockjs' // 引入mock方式一
let Mock=require('mockjs') // 引入mock方式二
​
//构建集合数据
var dataList = []
for (var i = 0; i < 53; i++) {dataList.push(Mock.mock({'id': '@increment','name': '@cname','phone': /^1[0-9]{10}$/,'email': '@email','address': '@county(true)','createTime': '@date("yyyy-MM-dd")'}))
}
​
//参数1:当前页  参数2:每页显示的条数  参数3:集合数据
//返回值:当前页的分页数据
function pagination(currentPage, pageSize, list) {console.log(list);console.log(currentPage, pageSize);//1 5//js的slice(开始索引,结束下标)是数组的截取方法,相当于字符串的substring,也是左闭右开的//例子:[1,2,3,4].slice(1,3) => [2,3]//假如集合有53条数据,当前页currentPage为1,每页pageSize5条,那么就是list.slice(0,5) - 就是前5条[第一条数据,第6条数据)//假如集合有53条数据,当前页currentPage为2,每页pageSize5条,那么就是list.slice(5,10) - 就是5-10条,就是第二页return list.slice((currentPage-1)*pageSize, currentPage*pageSize)
}
​
// 获取当前页的分页数据
//参数1:发送的请求地址  参数2:发送的请求方式   参数3中opts接收调用时传递的参数
//参数3即为.vue中调用是传递的参数:{"currentPage":1,"pageSize":5}
//返回值为totals【总数量】和 data【当前页的分页数据】
Mock.mock(new RegExp('/user/list'), 'post', (opts) => {var list =dataList;console.log("=======================user.js=====================");console.log(opts);//Object { url: "/user/list", type: "POST", body: "       {\"currentPage\":1,\"pageSize\":5}" }console.log(opts.body);//{"currentPage":1,"pageSize":5} - 参数传进来是json格式的字符串var currentPage = JSON.parse(opts.body).currentPage;//1var pageSize = JSON.parse(opts.body).pageSize;//5var totals = list.length;list = pagination(currentPage, pageSize, list)return {'totals': totals,//总条数'data': list//当前页数据}
})
2.2. 引入user.js
//在main.js中导入该js
import user from '../mock/user.js'

3. axios调用接口

上面只是模拟了一个接口,但是这个接口还必须得调用。vue更新到2.0之后,官方推荐使用axios请求服务器数据。axios和其他的ajax库都很类似,他是基于promise的http库,可以用在浏览器和node.js中

3.1. 安装axios
npm install axios --save
3.2. 使用axios调用接口
//User.vue中使用功能axios调用user.js中模拟的接口
<script>//引入axiosimport axios from "axios";export default {name: 'User',data(){return {tableData: [] //一开始是没有数据的}},mounted(){//页面被加载后,等到Vue实例挂载完毕之后再去获取实例,这个方法会自动触发axios.post("/user/list",{"currentPage":1,"pageSize":5}).then((result)=>{console.debug(result);//成功之后给数组赋值this.tableData = result.data.data;}).catch((result)=>{})}}
</script>

写在最后:mockjs是一个模拟动态数据的工具,在项目开发过程中有所运用。这篇博文给大家介绍了一些基础的知识,希望能够给大家带来帮助。笔者小,中,大厂均有面试经历,目前是一名全栈工程师,坚持分享java全栈知识,希望能够和大家共同进步。

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

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

相关文章

高创新 | CEEMDAN-VMD-GRU-Attention双重分解+门控循环单元+注意力机制多元时间序列预测

目录 效果一览基本介绍模型设计程序设计参考资料 效果一览 基本介绍 高创新 | CEEMDAN-VMD-GRU-Attention双重分解门控循环单元注意力机制多元时间序列预测 本文提出一种基于CEEMDAN 的二次分解方法&#xff0c;通过样本熵重构CEEMDAN 分解后的序列&#xff0c;复杂序列通过VMD…

转换模型时遇到“Unsupported slice step!”

在将 YOLOv5 模型从 ONNX 转换为模型时遇到“Unsupported slice step!”错误&#xff0c;这通常是因为 当前不支持某些特定的 ONNX 操作或参数配置&#xff0c;尤其是带有非标准切片步长的操作。 解决方案 修改模型或代码: 尝试修改模型中的切片操作&#xff0c;使其使用 支持…

Redhat 安装 docker 网络连接超时问题

目录 添加阿里云的Docker CE仓库 更新YUM缓存 安装 Docker Engine 启动并设置Docker自启动 验证 Docker 安装 [userlocalhost ~]$ sudo yum-config-manager --add-repohttps://download.docker.com/linux/centos/docker-ce.repo 正在更新 Subscription Management 软件仓库…

【网络协议】ISIS

ISIS IS-IS&#xff08;Intermediate System to Intermediate System&#xff0c;中间系统到中间系统&#xff09;协议是一种用于在自治系统&#xff08;AS&#xff09;内部进行路由选择的链路状态路由协议。它最初是为OSI&#xff08;开放系统互连&#xff09;网络设计的&…

Linux安装Jmeter及简单使用教程

Linux安装Jmeter 首先需要java环境 java --version官网 下载二进制包 #创建文件夹 sudo mkdir /usr/local/jmeter #解压 sudo tar zxvf apache-jmeter-5.6.3.tgz -C /usr/local/jmeter编辑配置文件 sudo vim /etc/profile&#xff0c;添加以下内容 export JMETER_HOME/usr/l…

Linux环境部署Python Web服务

“姑娘&#xff0c;再见面就要靠运气了&#xff0c;可别装作不认识&#xff0c;那句“好久不见”可干万别打颤…” 将使用 Python 编写的后端 API 部署到 Linux 环境中&#xff0c;可以按照以下详细步骤操作。本文将涵盖环境准备、API 编写、使用 Gunicorn 作为 WSGI 服务器、配…

1-3分钟爆款视频素材在哪找啊?这9个热门爆款素材网站分享给你

在如今快节奏的时代&#xff0c;短视频已成为吸引观众注意力的黄金手段。然而&#xff0c;要制作出1-3分钟的爆款视频&#xff0c;除了创意和剪辑技巧外&#xff0c;选择合适的素材至关重要。那么&#xff0c;哪里可以找到那些能让你的视频脱颖而出的爆款素材呢&#xff1f;不用…

鸿蒙开发:Universal Keystore Kit(密钥管理服务)【加解密(ArkTS)】

加解密(ArkTS) 以AES 128密钥为例&#xff0c;完成加解密。具体的场景介绍及支持的算法规格。 开发步骤 生成密钥 指定密钥别名。初始化密钥属性集。调用[generateKeyItem]生成密钥&#xff0c;具体请参考[密钥生成]。开发前请熟悉鸿蒙开发指导文档&#xff1a;gitee.com/l…

yolov8-seg分割模型TensorRt部署,去掉torch

已完成的yolov8-seg分割模型TensorRt部署 准备下载yolov8-seg模型转化为onnx和trt推理写好的推理接口 准备 https://github.com/songjiahao-wq/yolov8_seg_trtinference.git下载代码 安装TensorRt8.6版本&#xff0c;以及pip install -r requirements.txt 下载yolov8-seg模型…

FastAPI本身是一个高性能的Web框架

FastAPI本身是一个高性能的Web框架&#xff0c;它并不直接支持数据库操作&#xff0c;但可以通过集成各种数据库库来与各种数据库进行交互。FastAPI支持几乎所有的关系型数据库和非关系型数据库&#xff0c;这主要取决于你选择的数据库库&#xff08;如ORM库&#xff09;以及相…

【web APIs】快速上手Day05(Bom操作)

目录 Web APIs - 第5天笔记js组成window对象BOM定时器-延迟函数案例-5秒钟之后消失的广告 JS执行机制location对象案例-5秒钟之后跳转的页面 navigator对象histroy对象 本地存储&#xff08;今日重点&#xff09;localStorage&#xff08;重点&#xff09;sessionStorage&#…

三、mysql-万字长文读懂mysql

mysql 三、 Mysql3.1 基础3.1.1 mysql执行流程-组成架构3.2 索引3.2.1 索引底层的数据结构与算法分类在创建表时,InnoDB 存储引擎会根据不同的场景选择不同的列作为索引B+树结构3.2.2 为什么 MySQL InnoDB 选择 B+tree 作为索引的数据结构3.2.2.1. 从磁盘角度出发3.2.2.2. 数据…

深度解析移动硬盘“函数不正确”错误及高效恢复策略

在数据密集型的社会中&#xff0c;移动硬盘作为移动存储的重要载体&#xff0c;承载着无数用户的个人信息、工作资料及珍贵回忆。然而&#xff0c;当遭遇“函数不正确”的错误时&#xff0c;这些宝贵的数据仿佛被一层无形的屏障所阻隔&#xff0c;让人束手无策。本文将深入探讨…

如何选择高性价比的土壤检测仪器?

在现代农业与环保领域&#xff0c;土壤检测仪器的选择显得尤为关键。它不仅关系到土壤养分管理、作物健康生长&#xff0c;还涉及到环境保护和可持续发展。那么&#xff0c;面对市场上琳琅满目的土壤检测仪器&#xff0c;我们该如何选择一款实用的设备呢&#xff1f; 首先&…

(1)滑动窗口算法介绍与练习:长度最小的子数组

滑动窗口算法介绍 所谓滑动窗口&#xff0c;即为同向双指针移动过程中形成的间隔区域&#xff0c;并且这两个指针在移动的过程中不会回退 对于滑动窗口的题目可以抽象为三个步骤&#xff1a; 定义窗口两端指针left和right进入窗口判断离开窗口循环2、3和4步 滑动窗口练习 长度最…

昇思训练营打卡第十七天(基于MindNLP+MusicGen生成自己的个性化音乐)

MindNLP是一个基于MindSpore的自然语言处理&#xff08;NLP&#xff09;开源库。它提供了一系列常用的NLP方法&#xff0c;并支持解决各种自然语言处理任务的平台。MindNLP的设计目标是帮助研究人员和开发者更高效地构建和训练模型。 MindNLP的主要特点包括&#xff1a; 全面…

git要忽略对文件的本地修改

要忽略对文件的本地修改&#xff08;即&#xff0c;使Git忽略对该文件的任何未提交更改&#xff09;&#xff0c;可以使用以下命令将该文件标记为假设未更改&#xff08;assume-unchanged&#xff09;&#xff1a; sh git update-index --assume-unchanged runtime/x64/skin/s…

短视频电商源码的优势及软件架构解析

短视频电商源码是目前电商行业中非常火热的一个新兴领域&#xff0c;它通过短视频内容和电商商品的结合&#xff0c;为用户提供了一种新的购物体验。下面将介绍短视频电商源码的优势以及软件架构。 首先&#xff0c;短视频电商源码具有以下几个优势&#xff1a; 1、创新的购物体…

C#中的函数

函数是越单一越好 函数的命名规范 驼峰命名法&#xff1a;即首字母大写 多单词拼接时&#xff0c;所有单词首字母大写 internal class Program {static void Main(string[] args){int a 2;int b 3;int sum add(a, b);Console.WriteLine(sum); ​}/// <summary>///…

惠海 H6118 DCDC降压恒流芯片IC 30V36v40V降12V 9V LED景观灯舞台灯方案

H6118是一款连续电感电流导通模式的降压型LED恒流驱动器&#xff0c;用于驱动一个或多个LED 灯串。H6118工作电压从4V到30V&#xff0c;提供可调的输出电流&#xff0c;最大输出电流可达到1.2A。 H6118内置功率开关管&#xff0c;采用高端电流检测电路&#xff0c;支持PWM模式…