vue项目中使用mockjs模拟接口返回数据

  Mock.js 是一个模拟数据生成器,利用它,可以拦截ajax请求,直接模拟返回数据,这样前后端只要约定好数据格式,前端就不需要依赖后端的接口,可以直接使用模拟的数据了。

  网上介绍mock的教程也较多,不过大多数看的比较模糊。其实使用起来非常简单,这里介绍在Vue工程中使用Mockjs,并且实现开发和生产配置化。

一、安装

cnpm install --save-dev mockjs

二、引入

  为了只在开发环境使用mock,而打包到生产环境时自动不使用mock,我们可以在env中做一个配置

//dev.env
module.exports = merge(prodEnv, {
  NODE_ENV: ‘"development"‘,
  MOCK: ‘true‘,
})

//prod.env
module.exports = {
  NODE_ENV: ‘"production"‘,
  MOCK: ‘false‘,
}

  然后再main.js里面引入mockjs

process.env.MOCK && require(‘@/mock‘)
//表示配置MOCK为true的时候,才引入mock,所以生产环境的时候就不引入mock了

三、目录和文件创建

  在src目录下创建mock目录,添加index.js文件,这里建议给每类api使用单独的mock文件。例如下面一个api文件对应一个mock文件

  mock/index.js

//将所有的mock文件导入
require(‘./inspection‘)

// 在这里可以做一些通用的配置
const Mock = require("mockjs")
// 设置所有ajax请求的超时时间,模拟网络传输耗时
Mock.setup({
    timeout: 0-300
})

四、拦截ajax请求,配置mock的数据

const Mock = require("mockjs")
const Random = Mock.Random;

Mock.mock(‘/api/load‘,‘get‘,{
    ‘xData|100‘:[‘@datetime‘],
    ‘series|2‘:[{
        ‘name‘:‘@NAME‘,
        ‘type‘:‘line‘,
        ‘smooth‘:true,
        ‘data|100‘:[‘@integer(1,600)‘]
    }]
})

  拦截ajax请求主要可以使用Mock中的两个方法:

Mock.mock( rurl, rtype, template )
Mock.mock( rurl, rtype, function( options ) )

  rurl:表示需要拦截的 URL,可以是 URL 字符串或 URL 正则。(在vue 工程中,建议将api的url全部放在apipath中统一管理,然后在Mock中使用与发请求的时候使用的同一个引用)

  rtype:表示需要拦截的 Ajax 请求类型。例如 GET、POST、PUT、DELETE 等。

  template:表示数据模板,可以是对象或字符串。如果需要要把数据写死,可以直接写一个普通的对象。如果要让Mock随机生成,可以根据Mock模板的规则自定义。例如:

{ ‘data|1-10‘:[{}] } 表示生成生成包含 1到10个空对象的数据
‘@EMAIL‘ 表示随机生成一个email地址
‘@CNAME‘ 表示随机生成一个中文人名

  再就是函数,比如下面这样

Mock.mock(‘/api/redo‘,‘get‘,function(options){
    let    series=[];
    for(let n=1;n<18;n++){
        let _obj={};
        _obj.name = ‘05-‘ + (n <= 9 ? ‘0‘ + n : n);
        _obj.type = ‘line‘;
        _obj.data=[];
        for(let i=0;i<24;i++){
            let _d = Random.integer(1,10) * (i%2 == 0 ? 10 : 90);
            _obj.data.push(_d);
        }
        series.push(_obj);
    }
    return series;
})

  到此基本应用就可以了,更详细的使用,请看官方文档。

原文地址:https://www.cnblogs.com/goloving/p/9038701.html

时间: 2024-10-26 23:22:19

vue项目中使用mockjs模拟接口返回数据的相关文章

vue项目中利用popstate处理页面返回操作

需求背景:项目中需要做一个返回确认,避免用户误触返回键而退出当前页面. 原理:利用history和浏览器刷新popstate状态 实现: 1.在mounted() 阶段判断并添加popstate事件监听,History.pushState()(参数:一个状态对象,一个标题(现在被忽略了),以及一个可选的URL地址) 2.在methods里定义监听操作函数 3.页面销毁时,取消监听.(注意:一定要取消监听,否则其他vue路由页面也会被监听) 原文地址:https://www.cnblogs.com

使用mockjs模拟后端返回的json数据;

前后端分离开发中最重要的一部就是前后端联调,很多时候后端进度是跟不上前端的,所以需要前端模拟一些数据进行调试,这样前端的进度就可以加快了.后端的小哥哥别打我: 使用mockjs可以很方便的模拟出想要的数据,只要后端字段给好,就可以模拟出数据,等到后端的数据接口真真好的时候可以直接将接口换掉: 使用方法: 一:安装json-server   (ps:本人理解这是模拟一个后端服务器,到时候会开一个虚拟服务器出来) npm install json-server –g    二:在项目中安装mockj

在vue项目中的axios使用配置记录

默认vue项目中已经安装axios,基于element-ui开发,主要记录配置的相关. axiosConfig.js import Vue from 'vue' import axios from 'axios' import qs from 'qs' import { Message, Loading } from 'element-ui' // 响应时间 axios.defaults.timeout = 5 * 1000 // 配置cookie // axios.defaults.withC

Vue项目中遇到的一些问题总结

一.开发环境使用Ajax请求,报错 网上查的资料,在config中的index.js这样设置 proxyTable:{ '/api':{ target:'', //此处为你的API接口地址 changeOrigin:true, pathRewrite:{ '^/api':'' //这里理解为用api代替target中的地址 } } } 配置完后,请求依然报错,大致是https证书的问题 [HPM] Error occured while trying to proxy request /xxx/

vue项目中遇到的那些事。

前言 有好几天没更新文章了.这段实际忙着做了一个vue的项目,从 19 天前开始,到今天刚好 20 天,独立完成. 做vue项目做这个项目一方面能为工作做一些准备,一方面也精进一下技术. 技术栈:vue2 + vuex + vue-router + webpack + ES6/7 + element-ui + vue-baidu-map + i18n + vue-awesome-swiper 做项目时总是有一些思考和踩过的坑,对以后有一定的帮助,今天就来写写做vue项目遇到的那些事. 假如你正准

在vue项目中mock数据

第一步:安装: 在命令行中执行: npm install mockjs; 第二步:定义index.js文件 我们新建一个mock文件夹,此文件夹中建一个index.js文件:在index.js中输入以下内容: import Mock from 'mockjs' //引入mockjs,npm已安装import { Random } from 'mockjs' // 引入random对象,随机生成数据的对象,(与占位符@一样)Mock.setup({ timeout:1000 //设置请求延时时间}

在vue-cli搭建的项目中在后台mock接口中支持req.body和req.cookies

在<vue-cli搭建的项目中增加后台mock接口>中实现了后台mock,但是前端post的t数据都要在mock的后台接口中使用req的接收数据事件获取http协议body中的数据. req.on('data', function(chunk){ //接收字节数据 }); req.end('data', function(){ //转换||处理 }); req.error('error', function(e){ //处理错误 }); 如果前端需要使用cookie,后端要读取,那么在后台mo

Vue 项目中使用 jsPlumb

jsPlumb 介绍 jsPlumb 是一个强大的 JavaScript 连线库,它可以将 html中 的元素用箭头.曲线.直线等连接起来,适用于开发 Web 上的图表.建模工具.流程图.关系图等. jsPlumb 参考网站 博客园:http://www.cnblogs.com/leomYili/p/6346526.html?utm_source=itdadao&utm_medium=referral 官网:https://www.jsplumbtoolkit.com/ 安装 jsPlumb v

vue项目中使用阿里iconfont图标

在上一篇文章中介绍了如何在vue项目中使用vue-awesome,如果你想了解,请移步<vue项目中使用vue-awesome> 这里介绍一下vue项目中如何使用阿里的iconfont图标库,先看一下官网 可以看到有将近两百万的图标量,可以说我们想要的矢量图图标这里大部分都是有的,下面直接开始如何在vue项目中使用,方法有两种 方法一:简单粗暴法 1.打开 iconFont官网 选择自己喜欢的图标,并且添加购物车 例如我现在选择三个图标 点击购物车,添加至项目 为了方便可以给项目起一个名字 选