一:概念

Mock.js是一款模拟数据生成器,旨在帮助前端攻城师独立于后端进行开发,帮助编写单元测试。提供了以下模拟功能:

  • 根据数据模板生成模拟数据
  • 模拟 Ajax 请求,生成并返回模拟数据
  • 基于 HTML 模板生成模拟数据

官网: http://mockjs.com/

二:安装

cnpm install mockjs

三:数据模板定义规范DTD

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

// 属性名 name

// 生成规则 rule

// 属性值 value

'name|rule': value

属性名 和 生成规则 之间用竖线 | 分隔。生成规则 是可选的。生成规则 有 7 种格式:

'name|min-max': value

'name|count': value

'name|min-max.dmin-dmax': value

'name|min-max.dcount': value

'name|count.dmin-dmax': value

'name|count.dcount': value

'name|+step': value

生成规则的含义需要依赖属性值的类型才能确定。属性值 中可以含有 @占位符。属性值 还指定了最终值的初始值和类型.

// 使用 Mock
let Mock = require('mockjs')
let data = Mock.mock({
'list|5‐10': [{
'id|+1': 1,
'name|2‐3':'测试',
'phone|11':'1',
'point|122‐500':0,
'money|3000‐8000.2':0,
'status|1':true,
'default|1‐3':true,
'detail|2‐3':{'id':1,'date':'2005‐01‐01','content':'记录'}
}]
})
// 输出结果
console.log(JSON.stringify(data,null,2))

1.属性值是string

'name|count': string: 'phone|11':'1'

通过重复 string 生成一个字符串,重复次数等于 count

'name|min-max': string: 'name|2‐4':'测试'

通过重复 string 生成一个字符串,重复次数大于等于 min,小于等于 max

2.属性值是number

'name|+1': number: 'id|+1': 1

属性值自动加 1,初始值为 number

'name|min-max': number: 'point|122‐500':0

生成一个大于等于 min、小于等于 max 的整数,属性值 number 只是用来确定类型

'name|min-max.dcount': value : 'money|3000‐8000.2':0

生成一个浮点数,整数部分大于等于 min、小于等于 max,小数部分为dcount位

'name|min-max.dmin-dmax': number: 'money2|1000‐5000.2‐4':0

生成一个浮点数,整数部分大于等于 min、小于等于 max,小数部分保留 dmin 到dmax 位

3.属性值是boolean

'name|1': boolean : 'status|1':true

随机生成一个布尔值,值为 true 的概率是 1/2,值为 false 的概率同样是 1/2

'name|min-max': value : 'default|1‐3':true

随机生成一个布尔值,值为 value 的概率是 min / (min + max)

4.属性值是Object

'name|count': object : 'detail|2':{'id':1,'date':'2005‐01‐01','content':'记录'}

从属性值 object 中随机选取 count 个属性

'name|min-max': object : 'detail|2‐3':{'id':1,'date':'2005‐01‐01','content':'记录'}

从属性值 object 中随机选取 min 到 max 个属性

5.属性值是array

'name|count': array

通过重复属性值 array 生成一个新数组,重复次数为 count

'name|min-max': array : 'list|5‐10': [{...}]

通过重复属性值 array 生成一个新数组,重复次数大于等于 min,小于等于 max

四:数据占位符定义规范DPD

Mock.Random 是一个工具类,用于生成各种随机数据。Mock.Random 的方法在数据模板中称为『占位符』,书写格式为 @占位符(参数 [, 参数]) 。内置方法列表:

Basic: boolean,natural,integer,float,character,string,range,date,time,datetime,now

Image: image, dataImage

Color: color

Text: paragraph, sentence, word, title, cparagraph, csentence,cword, ctitle

Name: first, last, name, cfirst, clast, cname

Web: url, domain, email, ip, tld

Address: area, region,county

Helper: capitalize, upper, lower, pick, shuffle

Miscellaneous: guid, id

示例:

// 使用 Mock
let Mock = require('mockjs')
let data = Mock.mock({
'list|10': [{
'id|+1': 1,
'name':'@cname',
'ename':'@last',
'cfirst':'@cfirst',
'point':'@integer',
'birthday':'@date',
'pic':'@image',
'title':'@title',
'content':'@cword(100)',
'url':"@url",
'ip':"@ip",
'email':"@email",
'area':'@region',
'address':'@county(true)'
}]
})
// 输出结果
console.log(JSON.stringify(data,null,2))

1.基本方法

string 字符串: 'name':'@string'

integer 整数: 'point':'@integer'

date 日期: 'birthday':'@date'

可以生成随机的基本数据类型

2.图像方法

'pic':'@image'

image 随机生成图片地址

3.文本方法

@title: 标题 : 'title':'@title'

@cword(100) :文本内容 参数为字数 : 'content':'@cword(100)'

4.名称方法

cname :中文名称 : 'name':'@cname'

cfirst:中文姓氏 : 'cfirst':'@cfirst'

Last:英文姓氏 : 'ename':'@last'

5.网络方法

可以生成url ip email等网络相关信息

'url':"@url"

'ip':"@ip"

'email':"@email"

5.地址方法

@region 区域 : 'area':'@region'

@county 省市县 : 'address':'@county(true)'

最新文章

  1. Eclipse 报java.lang.OutOfMemoryError: PermGen space错
  2. Codeforces Round #342 (Div. 2)
  3. java 多线程断点下载demo
  4. Logistic Regression and Gradient Descent
  5. get post
  6. C# url 路径转换 相对路径 转换为 绝对路径
  7. jQuery数字加减插件
  8. 第九十二节,html5+css3移动手机端流体布局,开篇知识
  9. [ASP.NET教程] 防止表单重复提交
  10. JVM 指令
  11. Pycharm 安装 idea VIM
  12. 为静态博客生成器WDTP移植了一款美美哒主题
  13. leecode第七十八题(子集)
  14. Promise,Generator(生成器),async(异步)函数
  15. Python实现:十进制数与(2~16进制数)之间的互相转换
  16. Codeforces 483B - Friends and Presents(二分+容斥)
  17. pycharm+gitee
  18. centos7开机不进入图形界面
  19. MapReduce性能调优记录
  20. npm发包流程

热门文章

  1. HDU-3081-Marriage Match 2(最大流, 二分答案, 并查集)
  2. vue导航菜单动态展示
  3. Redis如何实现高可用【主从复制+哨兵机制+keepalived】
  4. 故障检测、性能调优与Java类加载机制
  5. Vue的编译过程
  6. windows如何禁用惹人烦的开机启动广告
  7. Jackson和fastjson简单用法及性能对比
  8. BZOJ 4883: [Lydsy1705月赛]棋盘上的守卫 最小生成树 + 建模
  9. ZOJ 1610 Count the Colors (线段树成段更新)
  10. 字符串处理工具StringUtils