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

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

1.一个简单的例子:

Mock.mock(‘http://123.com‘,{
    ‘name|3‘:‘fei‘,//这个定义数据的模板形式下面会介绍
    ‘age|20-30‘:25,
})

$.ajax({
    url:‘http://123.com‘,
    dataType:‘json‘,
    success:function(e){
       console.log(e)
    }
})

在这个例子中我们截获地址为http://123.com返回的数据是一个拥有name和age的对象,那么ajax返回的数据就是Mock定义的数据,返回的数据格式如下:

{
     name:‘feifeifei‘,
     age:26,
}

至于上面的定义模板数据的格式是什么意思,下面就给大家介绍。

2.介绍如何定义数据

数据模板中的每个属性由 3 部分构成:属性名、生成规则、属性值:

// 属性名   name
// 生成规则 rule
// 属性值   value
‘name|rule‘: value1.‘name|min-max‘: string   通过重复 string 生成一个字符串,重复次数大于等于 min,小于等于 max例子:‘lastName|2-5‘:‘jiang‘, 重复jiang这个字符串 2-5 次

2.‘name|count‘: string   通过重复 string 生成一个字符串,重复次数等于 count例子:‘firstName|3‘:‘fei‘, 重复fei这个字符串 3 次,打印出来就是‘feifeifei‘。

3.‘name|min-max‘: number   生成一个大于等于 min、小于等于 max 的整数,属性值 number 只是用来确定类型。例子:‘age|20-30‘:25, 生成一个大于等于 20、小于等于 30 的整数,属性值 25 只是用来确定类型

4.‘name|+1‘: number   属性值自动加 1,初始值为 number例子:‘big|+1‘:0, 属性值自动加 1,初始值为 0,以后每次请求在前面的基础上+1

5.‘name|min-max.dmin-dmax‘: number   生成一个浮点数,整数部分大于等于 min、小于等于 max,小数部分保留 dmin 到 dmax 位。例子:‘weight|100-120.2-5‘:110.24, 生成一个浮点数,整数部分大于等于 100、小于等于 120,小数部分保留 2 到 5 位

6.‘name|1‘: boolean   随机生成一个布尔值,值为 true 的概率是 1/2,值为 false 的概率同样是 1/2例子:‘likeMovie|1‘:Boolean, 随机生成一个布尔值,值为 true 的概率是 1/2,值为 false 的概率同样是 1/2。

7.属性值是对象:var obj={‘host‘:‘www.baidu‘,‘port‘:‘12345‘,‘node‘:‘selector‘}

  7-1.‘name|count‘: object  从属性值 object 中随机选取 count 个属性。
  例子:‘life1|2‘:obj, 从属性值 obj 中随机选取 2 个属性

  7-2.‘name|min-max‘: object  从属性值 object 中随机选取 min 到 max 个属性  例子:‘life1|1-2‘:obj, 从属性值 obj 中随机选取 1 到 2 个属性。

8.属性值是数组:var arr=[‘momo‘,‘yanzi‘,‘ziwei‘]

  8-1.‘name|1‘: array   从属性值 array 中随机选取 1 个元素,作为最终值  例子:‘friend1|1‘:arr, 从数组 arr 中随机选取 1 个元素,作为最终值。

  8-2.‘name|+1‘: array   从属性值 array 中顺序选取 1 个元素,作为最终值。  例子:‘friend2|+1‘:arr, 从属性值 arr 中顺序选取 1 个元素,作为最终值,第一次就是‘momo‘,第二次请求就是‘yanzi‘

  8-3.‘name|count‘: array   通过重复属性值 array 生成一个新数组,重复次数为 count。  例子:‘friend3|2‘:arr, 重复arr这个数字2次作为这个属性值,得到数据应该是[‘momo‘,‘yanzi‘,‘ziwei‘,‘momo‘,‘yanzi‘,‘ziwei‘]

  8-4.‘name|min-max‘: array   通过重复属性值 array 生成一个新数组,重复次数大于等于 min,小于等于 max  例子:‘friend3|2-3‘:arr,//通过重复属性值 arr 生成一个新数组,重复次数大于等于 2,小于等于 3

3.实际的ajax请求例子:
var arr=[‘momo‘,‘yanzi‘,‘ziwei‘]
        var obj={
            ‘host‘:‘www.baidu‘,
            ‘port‘:‘12345‘,
            ‘node‘:‘selector‘
        }

        Mock.mock(‘http://www.bai.com‘,{
            ‘firstName|3‘:‘fei‘,//重复fei这个字符串 3 次,打印出来就是‘feifeifei‘。
            ‘lastName|2-5‘:‘jiang‘,//重复jiang这个字符串 2-5 次。
            ‘big|+1‘:0, //属性值自动加 1,初始值为 0
            ‘age|20-30‘:25,//生成一个大于等于 20、小于等于 30 的整数,属性值 25 只是用来确定类型
            ‘weight|100-120.2-5‘:110.24,//生成一个浮点数,整数部分大于等于 100、小于等于 120,小数部分保留 2 到 5 位。
            ‘likeMovie|1‘:Boolean,//随机生成一个布尔值,值为 true 的概率是 1/2,值为 false 的概率同样是 1/2。
            ‘friend1|1‘:arr,//从数组 arr 中随机选取 1 个元素,作为最终值。
            ‘friend2|+1‘:arr,//从属性值 arr 中顺序选取 1 个元素,作为最终值
            ‘friend3|2-3‘:arr,//通过重复属性值 arr 生成一个新数组,重复次数大于等于 2,小于等于 3。
            ‘life1|2‘:obj,//从属性值 obj 中随机选取 2 个属性
            ‘life1|1-2‘:obj,//从属性值 obj 中随机选取 1 到 2 个属性。
            ‘regexp1‘:/^[a-z][A-Z][0-9]$/,//生成的符合正则表达式的字符串

        })

        $.ajax({
            url:‘http://www.bai.com‘,
            dataType:‘json‘,
            success:function(e){
                console.log(e)
            }
        })

4.如何实现数据 增 删 改 查 的模拟数据接口

下面我就模拟后端删除功能的接口实现

/*模拟删除数据的方式*/
var arr=[
    {name:‘fei‘,age:20,id:1},
    {name:‘liang‘,age:30,id:2},
    {name:‘jun‘,age:40,id:3},
    {name:‘ming‘,age:50,id:4}
]

Mock.mock(‘http://www.bai.com‘,‘delete‘,function(options){
    var id = parseInt(options.body.split("=")[1])//获取删除的id
    var index;
    for(var i in arr){
        if(arr[i].id===id){//在数组arr里找到这个id
            index=i
            break;
        }
    }
    arr.splice(index,1)//把这个id对应的对象从数组里删除
    return arr;//返回这个数组,也就是返回处理后的假数据
})
$.ajax({
    url:‘http://www.bai.com‘,
    type:"DELETE",
    data:{
        id:1//假设需要删除id=1的数据
    },
    dataType:‘json‘,
    success:function(e){
        console.log(e)
    }
})

至于更多的详细文档可以去官方网站查看,http://mockjs.com/,Mock.js简单易学,可以便于前端的快速开发,也可以自己定义好需要的格式,让后端配合你,按照你的格式编写他的后端代码。

时间: 2024-12-16 04:56:13

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

js + bootstrap 实现基本的增删改查功能 -- 兰

描述:利用原生js + bootstrap 实现基本的增删改查功能:包含两个文件(index.jsp 和 index.js) <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN

HBuilder webApp开发 Websql增删改查操作

来源:http://blog.csdn.net/zhuming3834/article/details/51471434 这段时间公司要求我们做原生iOS和安卓的都转做H5开发APP,使用的工具HBuilder.公司这么要求我们也就只能转行做了.大家都是小白,好在公司有两位H5大神,他们先给我们一些代码看看,所以,我们上手也比较快.在做APP的过程中用到了一些本地存储,关于本地存储大家可以看看<App离线本地存储方案> .里面我只说说Web SQL,因为里面的localstorage,plus

基于SpringBoot开发一个Restful服务,实现增删改查功能

在去年的时候,在各种渠道中略微的了解了SpringBoot,在开发web项目的时候是如何的方便.快捷.但是当时并没有认真的去学习下,毕竟感觉自己在Struts和SpringMVC都用得不太熟练.不过在看了很多关于SpringBoot的介绍之后,并没有想象中的那么难,于是开始准备学习SpringBoot. 在闲暇之余的时候,看了下SpringBoot实战以及一些大神关于SpringBoot的博客之后,开始写起了我的第一个SpringBoot的项目.在能够对SpringBoot进行一些简单的开发Re

用OC语言完成简易通讯录(实现增删改查)功能.

(注:使用MRC) 一.功能描述: main函数中通过使用Person类和AddressBook类,创建对象.调用方法,实现以下8个功能: 1).使用便利构造器创建四个Person类的实例(联系人). 姓名:Lucy 性别:女 电话:123 年龄:21 姓名:Joe 性别:男 电话:456 年龄:17 姓名:Baby 性别:女 电话:789 年龄:27 姓名:Linda 性别:女 电话:000 年龄:21 2).创建一个AddressBook类的实例对象(通讯录). 3).使用AddressBo

javascript生成表格增删改查 JavaScript动态改变表格单元格内容 动态生成表格 JS获取表格任意单元格 javascript如何动态删除表格某一行

jsp页面表格布局Html代码 <body > <center> <input type="text" value="111" id="mytext"> <table border="1" width="60%" id="mytable"> <tr> <td id="td1">第一行第一列<

Node.js、express、mongodb 入门(基于easyui datagrid增删改查)

前言 从在本机(win8.1)环境安装相关环境到做完这个demo大概不到两周时间,刚开始只是在本机安装环境并没有敲个Demo,从周末开始断断续续的想写一个,按照惯性思维就写一个增删改查吧,一方面是体验下node.js的魔力,二就是看看node.js.express和mongoose的API,其次就是把自己入门的过程记录下来,方便自己查看,再就是对入门的朋友起一个引导的作用. 敲demo的过程中感觉最爽的就是npm(Node Package Manager)是一个Node.js的包管理和分发工具.

ABP教程(四)- 开始一个简单的任务管理系统 - 实现UI端的增删改查

接上一篇:ABP教程(三)- 开始一个简单的任务管理系统 – 后端编码 1.实现UI端的增删改查 1.1添加增删改查代码 打开SimpleTaskSystem.sln解决方案,添加一个“包含视图的MVC 5控制器(使用EntityFramework)”TaskController控制器,添加成功后我们就能得到一个完整增删改查的功能了. 生成的代码是不能用在我们的这个示例里的,还需经过些许调整,经过调整后的代码如下: using System; using System.Net; using Sy

Node.js + MySQL 实现数据的增删改查

通过完成一个 todo 应用展示 Node.js + MySQL 增删改查的功能.这里后台使用 Koa 及其相应的一些中间件作为 server 提供服务. 初始化项目 $ mkdir node-crud && cd $_ $ yarn init -y && npx gitignore node 上面的命令创建了一个空文件夹 node-crud,进入之后初始化一个 package.json 以及创建 .gitignore 文件. 安装 Koa 并创建 app.js 以启动一个

微软Connect教程系列--自动生成增删改查页面工具介绍(二)

本章课程描述了vs2015的三个特点,其中主要将描述在vs2015下面,使用命令自动生成增删改查界面,具体如下: 1.web.config文件不在存在,用config.json替代,以适应支撑vs的插件化. 即config.json可以在项目中不存在,你可以用xml文件或其他方式创建数据库连接. 2.获取nuget包更便捷 打开project.json,在dependencies节点输入“Newtonsoft.json”,并选择好相应版本,保存后,vs的引用就会自动从nuget上下载newton