小程序——使用Easy Mock

使用Easy Mock

一、什么是Easy Mock

   Easy Mock 是一个可视化的能快速生成模拟数据的持久化服务。在实际开发中常见的Mock方式一般是将模拟数据直接写在代码里,利用JavaScript拦截请求或者利用 Charles、Fiddler等代理工具拦截请求,这样的开发效率比较低,并且产生的数据是写死的,不能去按照一定的规则去变化,并且浪费了非常多的时间,因此有了这个产品的出现,我们可以容易的访问数据,而且这些数据还是动态变化的,特别适合我们进行测试,学习成本非常低,可以说了解前后端请求的无论是参数式还是restful的,都可以进行生成和使用,可以说极大程度而减少了我们管理这些数据的复杂度,并且Easy Mock的官网非常简洁,查找和使用非常的方便,可以说是开发的必备工具吧。

  我们登录Easy Mock的官网可以看一下,每天的使用量和总共的使用量,如果我们还是不知道的话就有点out了呢~~

二、使用Easy Mock

  2.1、注册并登录

   我们在注册的时候同时也就登录了,现在是比较流行的设计了,减少了导航的次数,当然在某种场合还是实用的常规的校验方法。要记得登录的时候的密码,Easy Mock暂时不提供找回密码功能!

 

 2.2、创建自己的项目

  接下来我们看一下web界面,主要分为五个大的部分,其中project里面我们可以创建工程,工程分为两种:个人的和团队的,根据我们的需要来设定,第二个是workstation,当我们将工程的“☆”选中了之后,我们等工程就到了这个里面了,可以加快我们访问的速度,另外可以便于我们查找。除了这些之外,Docs也是非常有用的,里面有很多我们初学者需要掌握和使用的案例和详解,非常的有用。另外就是一些插件之类的github子项目,另外我们还可以对自己基本信息进行设置。

下面我们创建自己的项目,在project中,我们根据自己的需要,点击右下角这个不起眼的加号,就可以创建一个我们的项目了。或者我们使用“shift+?”可以查看一下我们的热键,我们可以看到一些导航的命令,此时我们按一下键盘上的‘n’就可以开始创建一个项目了呢。在项目中,我们根据自己的需要填写相应的信息,对于swagger部分我们先不用填写,之后我们就可以创建一个工程了。

 2.3、生成自己的接口

  在我们的工程中,我们可以根据实际需要创建相应的接口了,我们可以看到系统自动为我们的工程生成了一串字符串来唯一标示该工程,之后是我们的base url,要注意我们这里的协议是https的,便于我们开发很多程序的,我们可以看到一个“create mock”的按钮,我们点击了之后就可以开始创建属于我们自己的接口了。

首先我们看一下可以创建的种类,还是非常全的,现在框架下的请求也就这么多了吧。

    其次我们开始创建,在这里我们的url支持restful的风格呢,使用{id}/func或者:id/func都没关系的呢。最后就是我们最重要的数据部分了。Easy Mock 引入了Mock.js, 支持生成随机的文本、数字、布尔值、日期、邮箱、链接、图片、颜色等,支持扩展更多数据类型,支持自定义函数和正则。

  2.3.1、基础语法

{  "string|1-10": "★",  "string2|3": "abc",  "number|+1": 202,  "number2|1-100.1-10": 1,  "boolean|1": true,  "regexp": /[a-z][A-Z][0-9]/,  "absolutePath": "@/string @/user/name",  "user": {    "name": "demo"  },  "object|2": {    "310000": "上海市",    "320000": "江苏省"  },  "array|1": ["AMD"]}

   我们在浏览器中访问,再更新了接口之后,我们点击action中的预览即可。对于上面的语法我做一个简单的解释,首先,在‘|’左边的是我们要显示的属性key,在右边的‘1-10’是重复后面的value多少次的意思,从1到10每次随机选择,对于‘3’代表确定的三次,‘+1’就是自增的话加一自增。剩下的我们可以依次类推的,就这样我们的可扩展性就上去了,最有意思的是@string取了本json中的string中的value,这是一种新颖的东西,还有正则表达式的出现更是很有意思。

   2.3.2、数据占位符

   使用数据占位符,我们可以更加轻松地去模拟我们需要数据的类型、长度、大小、格式等等,非常的方便。

{  "string|1-10": "@string",  "integer": "@integer(10, 30)",  "float": "@float(60, 100, 2, 2)",  "boolean": "@boolean",  "date": "@date(yyyy-MM-dd)",  "datetime": "@datetime",  "now": "@now",  "url": "@url",  "email": "@email",  "region": "@region",  "city": "@city",  "province": "@province",  "county": "@county",  "upper": "@upper(@title)",  "guid": "@guid",  "id": "@id",  "image": "@image(200x200)",  "title": "@title",  "cparagraph": "@cparagraph",  "csentence": "@csentence",  "range": "@range(2, 10)"}

 2.4、掌握一些技巧

    到这个程度,我们还想提升的话,一个方向是了解一下Swagger的知识,另一个就是更加深入的理解一下我们的Easy Mock。

   2.4.1、响应式数据
    借助于响应式数据,也能玩出许多新花样,我们可以在数据编辑器 中,为某个属性指定一个 Function。在 Function 中,我们提供了 _req 对象,这使得我们可以通过请求对象编写逻辑,实现响应式数据。

{
  "success": true,
  "data": {
    "default": "zyr",
    _req: function({
      _req
    }) {
      return _req
    },
    name: function({
      _req,
      Mock
    }) {
      if (_req.query.name === ‘zyr‘) {
        return _req.query.name + ‘_‘ + Mock.mock(‘@name‘)
      } else {
        return this.default
      }
    }
  }
}

  当我们在后面加上如下参数之后我们发现在我们的参数之后确实又加了一些@name字符串。我们通过响应式数据对数据进行了处理。

https://www.easy-mock.com/mock/5af6be1c4a8e0f28cef5c4ac/zyr/response?name=zyr#!method=get

    响应式数据提高了数据的可扩展性和灵活性,但同时也带来了一些问题。例如:代码中出现了死循环,这些问题往往都是致命的,因此做了一些限制。如果生成数据的时间 超过1s,系统将会返回一个 timed out 的错误信息,此时应该检查代码是否出现了 异步操作 或 死循环。另外,无法在函数中使用 setInterval、setTimeout 等方法进行异步操作。

  2.4.2、自定义响应

  当定义的数据结构中包含 _res 字段的时候,会进入一个特殊逻辑,可以给返回的请求添加一些定制信息。
   status:可以定制返回的 http status code,默认是 200
   cookies:可以定制需要设置的 cookie(暂时不支持设置过期时间等)
   headers:可以定制返回的 response 的 header
   data:如果有这个字段,会以此数据直接覆盖整个返回的数据,并且此处不支持 mock 的语法(如果 _res.status 的值为 200,则不会覆盖默认定义的 mock 数据)

{
  "success": true,
  "data": {
    "default": "hah",
    "name": "zyr"
  },
  "user": {
    "sex": "male",
    "name": "zyr"
  },

  "_res": {
    "status": 400,
    "data": {
      "success": false,
      "sex": "male",
      "name": "zyr"
    },
    "cookies": {
      "test": "true"
    },
    "headers": {
      "Power": "zyr"
    }
  }
}

 

   当_res.status的值为 400 的时候,用户端接收到的响应将会是 _res.data中定义的数据,并且返回一个status code 为400的响应,响应的header中会包含一个叫做zyr的值,并为浏览器设置一个叫做zyr的 cookie。当想要返回正常的 mock 数据的时候,修改_res.status为 200,或者将整个_res删掉即可。 

    2.4.3、em.demo.all 

在数据编辑器中,输入 em.demo.all 按下回车,神奇的事情发生了。已经基于 Mock.js 语法自动创建好了数据对象.

 1 HTTP/1.1 200 OK
 2 Access-Control-Allow-Credentials: true
 3 Access-Control-Allow-Origin: https://www.easy-mock.com
 4 Connection: keep-alive
 5 Content-Length: 1644
 6 Content-Type: application/json; charset=utf-8
 7 Date: Sat, 12 May 2018 12:58:22 GMT
 8 Rate-Limit-Remaining: 0
 9 Rate-Limit-Reset: 1526129902
10 Rate-Limit-Total: 2
11 Server: Tengine
12 Vary: Accept, Origin
13 X-Request-Id: c4b9a7a8-0a8b-4c83-8308-78abb90bf53d
14
15 {
16   "base": {
17     "range": [
18       3,
19       4,
20       5,
21       6
22     ],
23     "string": "Mj%A$81]d",
24     "character": "a",
25     "float": 70.6,
26     "integer": 76,
27     "natural": 61,
28     "boolean": true
29   },
30   "date": {
31     "date": "2008-03-12",
32     "time": "19:20:11",
33     "datetime": "2016-05-25 12:53:49",
34     "now": "2018-05-12 20:58:22"
35   },
36   "image": {
37     "image": "http://dummyimage.com/200x100/50B347/FFF&text=EasyMock"
38   },
39   "color": {
40     "color": "#a1f279",
41     "hex": "#f279c4",
42     "rgb": "rgb(121, 232, 242)",
43     "rgba": "rgba(242, 217, 121, 0.61)",
44     "hsl": "hsl(269, 82, 71)"
45   },
46   "text": {
47     "paragraph": "Ionoxzmrch lokqznx weujgfqxm rsrppoic ulkwd oqsxpqmki gamobvgnsg qtvxhcsrt kiurnf kvwhlf qjikomms spdl sexubg gzfgyubvh wblf. Qvduv otuunseod sutclcx lol nxnwisg rewl okjrbk uea nrrozo yhi plyxzdokl bdhykzldmk pktlfhjo gqpmpl afvdqfy.",
48     "sentence": "Tpnnwictw hhucfdmq widhiwpj.",
49     "word": "kgl",
50     "title": "Ilz Iztcyeml Gxmicgews Ptbsmrp Tnyvthx",
51     "cparagraph": "义其史叫例家总住价准标作么地。般九众电包技心知可至价指社小资。表省就识白目进知争战位始进。",
52     "csentence": "力等使。",
53     "cword": "六八二八八十",
54     "ctitle": "并工元第建"
55   },
56   "name": {
57     "first": "David",
58     "last": "Perez",
59     "name": "Gary Jones",
60     "cfirst": "谭",
61     "clast": "平",
62     "cname": "余芳"
63   },
64   "web": {
65     "url": "nntp://yehhkhmwl.mr/htelpfrhen",
66     "domain": "bbjhmwzg.ne",
67     "protocol": "news",
68     "tld": "ht",
69     "email": "[email protected]",
70     "ip": "65.15.207.232"
71   },
72   "address": {
73     "region": "华中",
74     "province": "河南省",
75     "city": "西藏自治区 昌都地区",
76     "county": "吉林省 白山市 临江市",
77     "zip": "764604"
78   },
79   "helper": {
80     "capitalize": "Hello",
81     "upper": "HELLO",
82     "lower": "hello",
83     "pick": "i",
84     "shuffle": [
85       "u",
86       "e",
87       "a",
88       "o",
89       "i"
90     ]
91   },
92   "miscellaneous": {
93     "id": "430000200111207327",
94     "guid": "e28988fC-adfD-2AdA-cDBF-a88F2875CB2B",
95     "increment": 2648
96   }
97 }

3、总结

   工具的重要性在软件工程的开发中是不言而喻的,Easy Mock的功能可以说让我们的开发过程简化了很多,并且是免费的,因此很推荐大家使用,本文件要的介绍了一下主要的内容,大部分内容来自于官网,大家有兴趣的可以仔细查阅呢。

原文地址:https://www.cnblogs.com/zyrblog/p/9029746.html

时间: 2024-11-06 07:13:05

小程序——使用Easy Mock的相关文章

微信小程序 + mock.js 实现后台模拟及调试

一.创建小程序项目 mock.js 从 https://github.com/nuysoft/Mock/blob/refactoring/dist/mock.js 下载 api.js:配置模拟数据和后台接口数据,通过 DEBUG = true;//切换数据入口 let API_HOST = "http://xxx.com/xxx"; let DEBUG = true;//切换数据入口 var Mock = require('mock.js') function ajax(data =

搭建mock服务器(微信小程序)

搭建mock服务器(微信小程序) 如何在微信小程序使用mock.js实在是个问题,为了完全模拟访问路由和数据,选择在搭建本地mock服务器是一个不错的选择. 以下示例了一个mock服务器的搭建过程以及以学生为对象进行增删改查分页的示例. 前提要求 安装了node.js 创建服务器 我们在自己电脑上选择一个位置,创建一个新的文件夹mockServer,用vscode打开这个文件夹 使用命令安装以下模块 cnpm install express body-parser cors nodemon mo

微信小程序教学第二章(含视频):小程序中级实战教程之预备篇 - 封装网络请求及 mock 数据

§ 封装网络请求及 mock 数据 本文配套视频地址:https://v.qq.com/x/page/i0554... 开始前请把 ch2-3 分支中的 code/ 目录导入微信开发工具 上一节中,我们对 index.js 文件中增加了 util 对象,并在对象中封装了很多公用方法 let util = { log(){--}, alert(){--}, getStorageData(){--}, setStorageData(){--} } 本节中,我们对常用的网络请求方法 wx.reques

当微信小程序遇上filter~

在微信小程序的开发过程中,当你想要实现不同页面间的数据绑定,却为此抓耳饶腮时,不妨让微信小程序与filter 来一场完美的邂逅,相信会给你带来别样的惊喜~ 前段时间被安利了一个很实用的公众号-前端早读课,它简洁.大方的页面和方便.实用的功能深深地吸引着我~(^U^)ノ 恰好这段时间学了小程序,就自己仿着写了个前端早读课的小程序. 实现的功能 不同页面间的数据绑定 随机显示数组里的元素 实时显示系统的日期 鼠标点击和页面跳转等基本功能 swiper组件和template样式模板的使用 使用easy

微信小程序学习 动手撸一个校园网小程序

动手撸一个校园网微信小程序 高考完毕,想必广大学子和家长们都在忙着查询各所高校的信息,刚好上手微信小程序,当练手也当为自己的学校做点宣传,便当即撸了一个校园网微信小程序. 效果预览 源码地址:Github??求你的小星星- 准备工作 微信小程序开发者工具:腾讯开放了小程序个人开发平台,只需要一个微信号就可以成为小程序开发者了. 微信小程序设计指南:由于小程序是一个平台,所以平台上的开发者必须要遵守规范. ?easy-mock:使用easy-mock模拟后端数据,后面会简单介绍配置. 七牛云:使用

2-HelloWorld微信小程序

看千遍不如做一遍.先让我们来一起做一个最简单的HelloWorld吧. 1.下载安装微信小程序开发者工具,下载路径: https://mp.weixin.qq.com/debug/wxadoc/dev/devtools/download.html 根据你的操作系统类型,选择windows 64.windows 32或mac. 2.创建项目 ⑴ 添加项目 点击"添加项目"按钮,创建一个项目. ⑵ 项目的几个参数说明 没有 AppID 就选无AppID(如果乱写会报错,到时可能无法进入项目

让你的「微信小程序」运行在Chrome浏览器上,让我们使用WebStorm

「微信小程序」的开发框架体验起来,还不错--自带了UI框架.但是问题是他的IDE,表现起来相当的糟糕--其实主要是因为,我当时买WebStorm License买了好多年.所以,我觉得他的IDE真不如我这个付费好用. 而且,作为一个拥护自由和开源的 「GitHub 中国区首席Markdown程序员」.微信在「微信小程序」引导着Web开向封闭,我们再也不能愉快地分享我们的代码了. 如果我们放任下去,未来的Web世界令人堪忧. 好了,废话说完了: 文章太长不想看,可以直接看Demo哈哈: GitHu

真的炸了:让人头痛的小程序之『图片懒加载』终极解决方案

转载:请写明原文链接及作者名 '小小小' 小程序真的会取代一切?QQ群:139128168 ← 点击加群 微信小程序中,懒加载特效让人头疼不已,因为小程序完全没法操作dom,所以位置的操作在小程序中,变得极其的难~~ 先看特效: 我们将其拆分为如下几个步骤进行讲解~~ 1)如何获取图片的位置高度 先看一张图: 通过上图可以知道,图片位置高度其实可以通过img.height + margin值算出. js代码: arrHight[i] = Math.floor(i/2)*(img.height +

小程序猿都找到了工作经验的方式

小程序猿都找到了工作经验的方式 昨天下午把三方给了TP-LINK之后,为期将近两个月的找工作过程也算是告一个段落.两个月一路走来,压力巨大.人生的下一站究竟会在哪里,无法预測. 面对事业.家庭.爱情,总想找到一个最好的平衡点.选择Android开发,选择TP-LINK.选择深圳,这一路的选择必定会对未来产生极大的影响,而影响总是具有两面性. 未来的路应该怎么走.怎样把命运掌握在自己的手里,这值得深思. 感谢家人的支持.感谢女友的相伴,感谢朋友的建议,是你们让我有一种持续战斗的激情:相同感谢腾讯.