使用Mock.js快速模拟接口

Mock.js官网 http://mockjs.com/
Mock.js的Github地址 https://github.com/nuysoft/Mock/wiki

Mock.js可以在不修改既有代码的基础上,拦截 Ajax 请求,返回模拟的响应数据。

非工程项目中快速使用Mock,js
index.html文件结构如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>DEMO</title>
    <script src="http://mockjs.com/dist/mock.js"></script>
    <script src="http://code.jquery.com/jquery-2.1.1.min.js"></script>
    <script src="./mock.js"></script>
    <style type="text/css">
    </style>
</head>
<body>
    <div class="demo-wrapper">
        <span class="app">点击</span>
    </div>
    <script>
    </script>
</body>
</html>

接下来添加script标签中的代码,首先我们可以利用Mock.js快速生成一串数据

let data = Mock.mock({
    "list|3-10": [{
        "id|+1": 1,
        "name": "@cname"
    }]
})
console.log('data:', JSON.stringify(data, null, 2))

打印结果如下:

data: {
  "list": [
    {
      "id": 1,
      "name": "尹涛"
    },
    {
      "id": 2,
      "name": "康涛"
    },
    {
      "id": 3,
      "name": "武军"
    },
    {
      "id": 4,
      "name": "傅平"
    }
  ]
}

其中list数组中的数量是随机3-10个,id依次+1,name是随机生成的。
利用Mock.Random可以生成更多类型的数据,image方法更是可以直接生成定制的图片链接

let random = Mock.Random
let friends = ['小张', '小王', '小李', '小陈']
let data2 = {
    email: random.email(),
    image: random.image('200x100', '#00405d', '#fff', 'Mock.js'),
    name: random.cname(),
    url: random.url(),
    address: random.city(),
    bestfriend: random.pick(friends)
}
console.log('data2:', JSON.stringify(data2, null, 2))

打印出的代码示例:

data2: {
  "email": "p.oxlbik@msuh.il",
  "image": "http://dummyimage.com/200x100/00405d/fff&text=Mock.js",
  "name": "程秀兰",
  "url": "mailto://dtr.tp/zcbizzv",
  "address": "钦州市",
  "bestfriend": "小王"
}

接下来是重头戏,我们可以利用Mock.js生成的数据直接模拟接口,下面是在index.html引入的mock.js的文件代码

data2: {
  "email": "p.oxlbik@msuh.il",
  "image": "http://dummyimage.com/200x100/00405d/fff&text=Mock.js",
  "name": "程秀兰",
  "url": "mailto://dtr.tp/zcbizzv",
  "address": "钦州市",
  "bestfriend": "小王"
}

在index.html中发起请求

$(".app").click(function () {
    $.ajax({
        url: "yourdomain.com/getlist",
        type: 'get',
        dataType: 'json'
    }).done(function (data, status, xhr) {
        console.log(data, null, 2)
    })
})

此时运行代码,点击app元素,页面控制台会打印出来请求到的模拟数据

{user: Array(4)}
    0: {id: 1, name: "董霞", age: 24, birthday: "1999-10-15", city: "city", …}
    1: {id: 2, name: "谭静", age: 20, birthday: "2000-03-20", city: "city", …}
    2: {id: 3, name: "史平", age: 28, birthday: "2016-02-17", city: "city", …}
    3: {id: 4, name: "李霞", age: 27, birthday: "1970-05-19", city: "city", …}

注意,这里的点击事件,并没有发起真实的ajax请求,此时请求已经在本地就被Mock.js拦截了。

vue项目中使用Mock.js
1.安装Mock.js

npm install mockjs --save-dev

2.在项目中新建mock.js文件,内容如下

const Mock = require('mockjs')
const Random = Mock.Random
const newsData = function () {
    let articles = []
    for (let i = 0; i < 10; i++) {
        let newsObj = {
            date: Random.date(),  //年月日
            longDate:Random.datetime(), //精确到时分秒
            number:Random.natural(201,205),  //数字
            image:Random.image(),      //图片
            flag:Random.boolean(),  // true-false
            name:Random.cname(),     //姓名
            url:Random.url(),       //url地址
            province:Random.province(),  //省
            city:Random.city(),     //市
            county:Random.county()  //区
        }
        articles.push(newsObj)
    }
    return {
        code: 0,
        msg: "操作成功",
        data: articles,
    }
}
Mock.setup({
    timeout: 500
})
``请严格注意get请求的地址``
Mock.mock('/api/user/myTranferRecord', 'post',newsData )   //post请求
Mock.mock(RegExp("/api/user/myTranferRecord"+".*"), 'get', newsData)   //get请求

3.在main.js中引入文件mock.js

import './mock'

4.页面中进行使用

this.$axios.post('/api/user/myTranferRecord').then(res=>{
 console.log(res) //这里返回的就是我们在mock中自定义的数据
})

此时就可以在页面中看到请求被拦截后拿到的模拟接口的数据

特别注意:
在实践过程中,发现 Mockjs 本身对get请求的支持并不是很友好。
举个例子,使用 Mock.mock("/user/getUserInfo ", "get", mockData) 的时候,它只会拦截url等于 /user/getUserInfo 的请求,而对于带参数的请求,如/user/getUserInfo?id=xxx,因为不等于 /user/getUserInfo 就拦截不到。
采用如下写法即可:

Mock.mock(RegExp("/user/myTranferRecord"+".*"), 'get', newsData)

另外,如果请求没有被拦截,多数是因为接口地址和mock.js文件中定义的接口地址不一样,导致拦截失败。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345

推荐阅读更多精彩内容