【mock.js】后端不来过夜半,闲敲mock落灯花 (附Vue + Vuex + mockjs的简单demo)

mock的由来【假】

赵师秀:南宋时期的一位前端工程师

诗词背景:在一个梅雨纷纷的夜晚,正处于项目编码阶段,书童却带来消息:写后端的李秀才在几个时辰前就赶往临安度假去了,!此时手头仅有一个简单的数据接口文档的赵师秀慨叹一声:"好吧,那还是我自己先模拟一下后端的接口吧"

_(:3 」∠)_  再后来,就有了那句千古名句啦~~( 为了表示对赵师秀先生的歉意,文末我将附上原文)

 

如果我说这就是前后端分离思想和mock.js的由来,你会信么?(?´ω`?)

mock的由来【真】

我们在Vue或React的文档里时不时就会看到这个名词,那么mock到底是什么东西呢?

mock有“愚弄、欺骗”之意,在前端领域,mock可以理解为我们前端开发人员制造的假数据。也就是说不是由后台真实制造,而是由我们其他一些方式模拟的数据,例如借助mock.js。

通过这种方式,我们能在一定程度上实现前后端分离的开发流程。因为如果前端开发人员能够自己模拟数据的话,就不必等着拿到后端的接口才能完成剩下的工作,使得前端人员独立开发的能力增强,在此基础上做到前端后台各自独立的开发(当然这个前提是有写好详细地公共数据接口的文档)

最后对接的工作是前后端联调数据,因为前端mock的辅助,我们尽可能地减少了前后端对接过程中的效率损耗

mock.js初上手——安装和使用

在终端里通过运行npm install mockjs去安装mock.js模块,安装成功后你就可以通过模块化的方式去使用模块化的方式去使用mock了,下面这个是官方文档的小例子:

var Mock = require(‘mockjs‘)
var data = Mock.mock({
  // 属性 list 的值是一个数组,其中含有 1 到 10 个元素
  ‘list|1-10‘: [{
    // 属性 id 是一个自增数,起始值为 1,每次增 1
    ‘id|+1‘: 1
  }]
})
// 输出结果
console.log(JSON.stringify(data, null, 4))

demo:

mock.js抢鲜看——主要的作用和API

mock.js的作用

mock.js的作用,从它文档的首页介绍便可以略知一二:

1.它可以生成大量不同类型的模板数据,从最基本的随机数组/数字/对象/字符串,再到一个域名,一个地址(省/市),一个标题,一段文字,甚至给定宽高和颜色的图片,它都能模拟生成! 这就是mock.js的强大之处

2. 相比起生成随机的模拟数据,其实我们更关心的是当我们发送Ajax请求的时候,我们能够接收到这些数据,这就是mock.js的第二大作用:拦截Ajax请求,当你对一个mock.js所指定的URL发起Ajax请求的时候,mock.js会将1中的模板数据作为响应数据回传给你,从而让你开发能在相当于已经拿到后端接口的前提下进行前端开发!

【注意】:mock.js只拦截Ajax,而不是fetch,所以,习惯于使用fetch的API的朋友们要注意了

mock的API其实非常简单,主要要用到的API其实就两个(我是说主要哈~~):

1.Mock.Random

这是一个对象,对象里包含许多可供调用的方法,返回相应的模拟数据,例如Mock.Random.domain() 可以返回一个随机的域名,Mock.Random.csentence() 可以返回一个随机的中文句子

2.Mock.mock([你发起Ajax请求的URL], ["get"或"post"],[根据Mock.Random定制的模板或函数])

调用这个方法后你就可以发起Ajax请求并且接收到你私人定制的随机数据啦!

【注意】前两个参数是字符串,最后一个参数是对象或函数

所以下面我就主要围绕这两点展开

Mock.Random的运用

模拟Web数据:

生成随机域名(每次运行结果不同):

var Random = Mock.Random
Random.domain()  //   "nhou.org.cn"

生成随机IP(每次运行结果不同)

var Random = Mock.Random
Random.ip()   //  "74.97.41.159"

生成随机URL(每次运行结果不同)

Random.url()  //   "news://wrmt.na/rbcgbws"

模拟地理位置数据:

生成随机省份:

var Random = Mock.Random
Random.province()  //"海南省"

生成随机城市:

var Random = Mock.Random
Random.city()   // "澳门半岛"

生成在某个省份的某个城市:

var Random = Mock.Random
Random.city(true) // "广东省 广州市"

模拟文本数据:

生成一条随机的中文句子:

var Random = Mock.Random
Random.csentence()   //  "会候权以解包党心要按总场火义国而片精。"

【注意】

1.默认一条句子里的汉字个数在12和18之间

2. 通过Random.csentence( length )指定句子的汉字个数:

Random.csentence(5)  // "文斗领拉米。"

3.通过Random.csentence( min?, max? )指定句子汉字个数的范围:

Random.csentence(3, 5)  // "住验住"

生成随机的中文段落:

var Random = Mock.Random
Random.cparagraph()  
// "电力速率离老五准东其引是外适只王。体区先手天里己车发很指一照委争本。究利天易里根干铁多而提造干下志维。级素一门件一压路低表且太马。"

【注意】

1. cparagraph可以看作是多条csentence以逗号连接后的字符串,默认条数为 3 到 7条csentence

2.通过Random.cparagraph(length )指定句子的个数

Random.cparagraph(2) 

// "而易除应精基还主局按选际复格从导。天第们国分比积造业王该回过白亲。"

3.通过Random.cparagraph(min?, max?)指定句子的个数的范围:

Random.cparagraph(1, 3)

//  "作养装军头确应当号天革来人车号把文。证细专物转民相解状律极或经较把马。其省级支际标业强龙算建物况。"

模拟颜色数据:

var Random = Mock.Random
Random.rgba()  // "rgba(122, 121, 242, 0.13)"

模拟日期/时间数据:

日期:

Random.date(‘yyyy-MM-dd‘)  // "1975-04-27"
Random.date(‘yy-MM-dd‘)    //   "00-01-08"

时间:

Random.time()   // "05:06:06"

模拟图片:

Random.image(‘200x100‘, ‘#4A7BF7‘, ‘Hello‘)

不指定参数则取随机的宽高并显示对应的宽高数据:

模拟姓名数据:

模拟全名:

Random.cname()   // "黄秀英"

模拟姓氏:

Random.cfirst()   // "龙"

模拟名字

Random.clast()  // "秀英"

Mock.mock()的运用

除了制造模拟数据之外,更关键的是,我们发起Ajax请求的时候要能够接收到这些数据呀。嘿嘿,这就是Mock.mock()的作用啦!

上面我介绍过Mock.mock()的用法,如下:

Mock.mock([你发起Ajax请求的URL], ["get"或"post"],[根据Mock.Random定制的模板或函数])

在文章开头的时候,我们通过使用mock函数的第三个参数生成了对应的模拟数据:

var data = Mock([模板参数]);

但如果我们希望这个数据能够被请求某个URL的ajax接收到,那就要运用到前两个参数了:

用例如下:

[注意] 为了在Vue中使用Ajax,我注册了一个插件:Vue-Resource,关于更多可以参考Vue-Resource的官方文档:https://github.com/pagekit/vue-resource/blob/develop/docs/config.md

import Vue from ‘vue‘
 
//注册Vue-Resource插件,这样我们就可以Vue.http.get(URL)去发出Ajax请求了
import VueResource from ‘vue-resource‘
Vue.use(VueResource)
 
var Mock = require(‘mockjs‘)
Mock.mock(‘/penghuwan.com/‘, ‘get‘, {
  // 属性 list 的值是一个数组,其中含有 1 到 10 个元素
  ‘list|1-10‘: [{
    // 属性 id 是一个自增数,起始值为 1,每次增 1
    ‘id|+1‘: 1
  }]
})
// 输出结果
 
Vue.http.get(‘/penghuwan.com/‘).then(
  response => {
    console.log(response.body)
  }
)

demo:

Mock.js小练兵——用Vue + Vuex + mockjs搭建一个简单的文章Feed

下面,我将用用Vue + Vuex + mockjs搭建一个简单的应用,展示前后端分离的工作流程

先看看我们最终要达到的效果,这是UI的最小单元:

我们希望能显示多个文章卡片,并且向其中插入mockjs模拟的内容

我的主要文件有四个:

├── app.vue          // 页面UI

├── main.js            // 入口文件,初始化vuex和vue-resource,并挂载mockjs

├── mock.js           // 生成模拟数据

└── module.js        // vuex的module部分

app.vue:

<template>
  <div id="app">
    <template v-for ="(item, index) in articles">
      <div :key="index">
        <h1 class="title">{{ item.title }}</h1>
        <div>
          {{ item.content }}
        </div>
        <div>
          <p class="time">{{ ‘发表时间:‘ +  item.time}}</p>
          <p class="location">{{ ‘发表地址: ‘ + item.location }}</p>
        </div>
      </div>
    </template>
  </div>
</template>
 
<script>
import { mapGetters, mapActions } from ‘vuex‘
 
export default {
  mounted: function () {
    this.fetchData()
  },
 
  methods: {
    ...mapActions({
      fetchData: ‘fetchArticlesData‘
    })
  },
 
  computed: {
    ...mapGetters({
      articles: ‘getArticles‘
    })
  }
}
</script>
 
<style scoped>
  #app div{
    border: 1px solid gray;
    padding: 10px;
    margin: 10px;
    overflow: hidden;
  }
 
  #app p{
    margin: 0px;
  }
 
  .title{
    font-size: 16px;
  }
 
  .time{
    float: left;
  }
 
  .location{
    float: right;
  }
</style>
 

入口文件main.js:

import Vue from ‘vue‘
import Vuex from ‘vuex‘
import VueResource from ‘vue-resource‘
 
import App from ‘./app‘
import article from ‘./module.js‘
 
Vue.use(Vuex)
Vue.use(VueResource)
 
// 调用mock的API,使Ajax能够捕获随机数据
require(‘./mock.js‘)
// 创建Vuex的store
const store = new Vuex.Store({
  modules: {
    article
  }
})
 
new Vue({
  el: ‘#app‘,
  template: ‘<App />‘,
  store: store,
  components: { App }
})

mock.js:

var Mock = require(‘mockjs‘)
var Random = Mock.Random
 
const produceData = function () {
  let articles = []
  for (let i = 0; i < 10; i++) {
    let newArticleObject = {
      title: Random.csentence(5),
      content: Random.cparagraph(5, 7),
      time: Random.date() + ‘ ‘ + Random.time(),
      location: Random.city()
    }
    articles.push(newArticleObject)
  }
  return {
    articles: articles
  }
}
// 第三个参数可以是对象也可以是返回对象的函数
Mock.mock(‘/article‘, ‘get‘, produceData)

module.js:

import Vue from ‘vue‘
 
const RESQUEST_ARTICLES = ‘RESQUEST_ARTICLES‘
 
export default {
  state: {
    articles: []
  },
 
  getters: {
    getArticles: state => state.articles
  },
 
  actions: {
    fetchArticlesData (context) {
      context.commit(RESQUEST_ARTICLES)
    }
  },
 
  mutations: {
    [RESQUEST_ARTICLES] (state) {
      Vue.http.get(‘/article‘).then(
        response => {
          let data = response.body
          state.articles = data.articles
        }
      )
    }
  }
}

demo:

再刷新一次看看!!:

【完】

黄梅时节家家雨,青草池塘处处蛙。有约不来过夜半,闲敲棋子落灯花

参考资料:

1.mock.js官方文档: http://mockjs.com/

2.vue-resource官方文档: https://github.com/pagekit/vue-resource

3.vuex中文文档: https://vuex.vuejs.org/zh-cn/

时间: 2024-08-11 09:48:37

【mock.js】后端不来过夜半,闲敲mock落灯花 (附Vue + Vuex + mockjs的简单demo)的相关文章

Mock.js简易教程,脱离后端独立开发,实现增删改查功能

在我们的生产实际中,后端的接口往往是较晚才会出来,并且还要写接口文档,于是我们的前端的许多开发都要等到接口给我们才能进行,这样对于我们前端来说显得十分的被动,于是有没有可以制造假数据来模拟后端接口呢,答案是肯定的.应该有人通过编写json文件来模拟后台数据,但是很局限,比如增删改查这些接口怎么实现呢,于是今天我们来介绍一款非常强大的插件Mock.js,可以非常方便的模拟后端的数据,也可以轻松的实现增删改查这些操作. 1.一个简单的例子: Mock.mock('http://123.com',{

前后端分离——前端项目使用Mock.js 模拟数据

一.简单介绍一下Mock.js 众所周知Mock.js因为两个重要的特性风靡前端: 数据类型丰富支持生成随机的文本.数字.布尔值.日期.邮箱.链接.图片.颜色等.(详情见官网) 拦截 Ajax 请求不需要修改既有代码,就可以拦截 Ajax 请求,返回模拟的响应数据.安全又便捷 文章会用到的API(也是Mock经常使用的API): Mock.mock(url, type, data) 参数名 参数需求 参数描述 例子 url 可选: URL 字符串或 URL 正则 拦截请求的地址 /mock ty

使用 mock.js 让前端开发与后端独立

直接上代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="http://cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script> <scrip

axios + mock.js模拟数据实现前后端分离开发的实例代码

首先就是必须安装axios和mock.js npm install axios npm install mockjs 1. 然后在文档src中新建一个mock.js文件,如图 2. 在main.js中全局引入axios插件和mock.js文件如图 3. 在组件中用axios获取mock.js文件 4. 在mock.js mockjs的用法可以到官网了解:http://mockjs.com(小生初学mock.js有不当之处请指出) 原文地址:https://www.cnblogs.com/mei1

Mock.js 与 fiddler 前端模拟数据与拦截请求

最近 工作需要  接触了Mock.js. Mock.js 是一款模拟数据生成器,旨在帮助前端攻城师独立于后端进行开发,帮助编写单元测试.提供了以下模拟功能: 根据数据模板生成模拟数据 模拟 Ajax 请求,生成并返回模拟数据 基于 HTML 模板生成模拟数据 http://mockjs.com/ 什么入门之类的 看官网就会~~~ Fiddler   web调试利器 便于我们调试前后端数据等. Fiddler是一个web调试代理.它能够记录所有客户端和服务器间的http请求,允许你监视,设置断点,

mock.js的真实数据模拟

哈哈,怎么说,这应该是我的第一个随笔了,毕竟前端之路上一直在学习并且各位大神们的经验,虽然也有不少的坑,但是总是收获比较多,所以我也想把一些收获记录下来,有需要的可以参考参考. 网上看了不少大神很多例子很好,但是介绍模糊,看了不知道具体做法,所以我会介绍的详细一点. 今天是主要分享一下mock.js 的插件,我觉得很不哦错,实用性很强,它可以在后端数据没写好的情况下,模拟真实数据,拦截ajax请求并作出迅速的反馈 mock.js官网上有下载,不过注意下载完以后只需要提取一个有用的js文件就行 然

Mock.js的使用

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 17.0px Consolas } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 17.0px Consolas; min-height: 20.0px } span.Apple-tab-span { white-space: pre } MOCK.js 安装及使用 一.mock.js 简介 生产随机数据,拦截ajax请求. 1.前后端分离:让前端工程师独立于

Mock.JS拦截HTTP请求实例解析-JS笔记

MockJS是一种比较通用的前端模拟HTTP请求及回复的工具,能够仿真处各类HTTP的请求及返回结果.实现在无后端的情况下,前端对于后端接口的仿真.Mock的基础使用也是比较简单,本文我们主要和大家分享Mock.JS拦截HTTP请求实例解析,希望能帮助到大家. 但,在引入MockJS时,import Mock from 'mockjs'会拦截所有前端发出的HTTP请求,无论是否使用Mock.mock开启Mock仿真,都会拦截HTTP请求. 这也就是为何,就算不Mock.mock也会后端无法获取前

Mock.js开发中拦截Ajax

Mock.js 是一款前端开发中拦截Ajax请求再生成随机数据响应的工具.可以用来模拟服务器响应. 优点是非常简单方便, 无侵入性, 基本覆盖常用的接口数据类型. 在我们的生产实际中,后端的接口往往是较晚才会出来,并且还要写接口文档,于是我们的前端的许多开发都要等到接口给我们才能进行,这样对于我们前端来说显得十分的被动,于是有没有可以制造假数据来模拟后端接口呢,答案是肯定的.应该有人通过编写json文件来模拟后台数据,但是很局限,比如增删改查这些接口怎么实现呢,于是今天我们来介绍一款非常强大的插