首页 > 编程学习 > 通过mockjs生成随机响应数据

通过mockjs生成随机响应数据

发布时间:2022/10/1 4:22:00

今天给大家带来通过mock为每个组件准备模拟数据,生成随机响应数据,如果哪里不对,请多多指教。

1. mockjs介绍(为每个组件准备模拟数据)

Mock.js是一个模拟数据的生成器,用来帮助前端调试开发、进行前后端的原型分离以及用来提高自动化测试效率。众所周知Mock.js因为两个重要的特性风靡前端,由于前后端是分离的,所以为了前端编写时候方便测试,我们就可以编写一个mock来测试ajax提交数据是否成功

官网http://mockjs.com目的

  • 数据类型丰富
  • 支持生成随机的文本、数字、布尔值、日期、邮箱、链接、图片、颜色等。
  • 拦截Ajax请求
  • 不需要修改既有代码,就可以拦截Ajax请求,返回模拟的响应数据。

2.效果展示

登陆成功后

实现mockjs发送数据效果展示

3. 如何使用 mockjs

以下这些前提是必须要确定nodejs环境已经安装好的

1)安装mockjs依赖

# -D表示只在开发环境中使用
npm install mockjs -D

2)在config目录下配置mockjs 

开发环境配置如下

module.exports = merge(prodEnv, {
  NODE_ENV: '"development"',
  //增加配置
  MOCK:'true'
})

生产环境配置如下

module.exports = {
  NODE_ENV: '"production"',
  //新增mockjs配置
  MOCK:'false'
}

 修改main.js

process.env.MOCK && require('@/mock')

注:

  1. process对象是Node的一个全局对象,提供当前Node进程的信息
  2. process.env返回环境变量 
  3. import是ES6标准中的模块化解决方案,require是node中遵循CommonJS规范的模块化解决方案,后者支持动态引入,也就是require(${path}/xx.js)

3)创建目录和index文件

在src目录下创建mock目录,定义mock主文件index.js,并在该文件中定义拦截路由配置,/src/mock/index.js

//引入mockjs,npm已安装
import Mock from 'mockjs'

//引入封装的请求地址
import action from '@/api/action'

//全局设置:设置所有ajax请求的超时时间,模拟网络传输耗时
Mock.setup({
  //延时400s请求到数据
  // timeout: 400
  //延时200-400s请求到数据
  timeout: 200 - 400
})

4)通过mockjs模拟发送数据

每个组件准备模拟数据,为每个组件(*.vue)准备模拟数据。然后导入到mock/index.js中

这里我们引入编辑好模拟数据login-mock.js

//引入mockjs,npm已安装
import Mock from 'mockjs'

//引入封装的请求地址
import action from '@/api/action'

//将模拟数据导入到这里。
import loginData from '@/mock/json/login-mock.js'

//获取请求的url
let url = action.getFullPath("SYSTEM_USER_DOLOGIN");


//Mock.mock(url, "post", loginData);

//执行发送模拟请求
Mock.mock(url, /post|get/i, loginData);


//全局设置:设置所有ajax请求的超时时间,模拟网络传输耗时
Mock.setup({
  //延时400s请求到数据
  // timeout: 400
  //延时200-400s请求到数据
  timeout: 200 - 400
})

5)准备模拟数据,编辑login-mock.js

//为增加可读性loginData与mack/index.js中导入的名称对应
const loginData = {
  "success": true,
  "msg": "密码正确"
}

//将当前模块导出,导出后index.js才可以导入
export default loginData

注: 

  1. url  请求url
  2. post 请求方式
  3. loginData  模拟数据
  4. mockjs  会拦截发送的请求,并使用模拟数据充当真实返回的响应数据
  5. Mock.mock(url, /post|get/i, loginData);   执行模拟发送请求
  6. export default loginData  将当前模块导出,导出后index.js才可以导入

通过路由跳转 常用方式

  • 字符串: this.$router.push('/home/first')
  • 对象: this.$router.push({ path: '/home/first' })
  • 命名的路由:
    this.$router.push({ name: 'home', params: { userId: wise }})
    params为传递的参数

this.$router.push、replace、go的区别

this.router.push(): 跳转到不同的url,这个方法会向history栈添加一个记录,点击后退会返回到上一个页面 this.router.replace() : 同样是跳转到指定的url,但是这个方法不会向history里面添加新的记录,点击返回,会跳转到上上一个页面。上一个记录是不存在的。
this.$router.go(n):相对于当前页面向前或向后跳转多少个页面,类似 window.history.go(n)。n可为正数可为负数。负数返回上一个页面

Copyright © 2010-2022 mfbz.cn 版权所有 |关于我们| 联系方式|豫ICP备15888888号