mock.js的粗浅理解

这篇博客详细介绍了Mock.js的基础用法,包括如何通过cdn引入,设置数据模板生成随机数据,如'name|3':'lz'生成重复属性,以及模拟Ajax请求。还提供了模拟数据接口的添加和查找操作示例,帮助初学者理解Mock.js在模拟API数据方面的应用。

mock.js使用

首先鄙人初入程序员的小白一枚,今天学习了mock.js,刚开始看的时候是真的一脸懵,进入官网去看mock.js也是看不懂,后来老师推荐了一个博客的写的内容就是mock.js的使用教程,同时也比官网上看的更容易理解了一些。
呐,就是这个链接啦,有兴趣的可以点进去看一看(点我)
首先的话用
cdn引入文件:

Mock.mock('http://www.bai.com',{'name|3':'lz','age|20-60':25})
         //url,请求路径。       //请求的数据。 
 
$.ajax({
    url:'http://www.bai.com',
    dataType:'json',``
    success:function(data){
        console.log(data)
    }
})

数据模板

上面的代码中

   {'name|3':'lz'}  此为模板数据格式

    属性名name、  生成规则: 重复属性自3次 ,   属性值:lz

1.‘name | min-max’: string 通过重复 string 生成一个字符串,重复次数大于等于 min,小于等于 max

  1. ‘name | count’: string 通过重复 string 生成一个字符串,重复次数等于 count

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

4.‘name | +1’: number 属性值自动加 1,初始值为 number

5.‘name | min-max.dmin-dmax’: number 生成一个浮点数,整数部分大于等于 min、小于等于 max,小数部分保留 dmin 到 dmax 位。

6 .‘name | 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个属性。  

         7-2.'name | min-max': object  从属性值 object 中随机选取 min 到 max 个属性

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

   8-1.'name|1': array   从属性值 array 中随机选取 1 个元素,作为最终值

   8-2.'name|+1': array   从属性值 array 中顺序选取 1 个元素,作为最终值。
   8-3.'name|count': array   通过重复属性值 array 生成一个新数组,重复次数为 count。
   8-4.'name|min-max': array   通过重复属性值 array 生成一个新数组,重复次数大于等于 min,小于等于 max
   

转自(https://blog.csdn.net/qq_42205731/article/details/81705350);

一个基础的增删改查模拟数据接口

删除例子在上面那个链接上已经有了所以在此就写一个添加
一个查找吧

添加例子:
模拟添加数据的接口

			    {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','push',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.push([{name:'fei',age:20,id:1}])//把这个id对应的对象添加到数组中
				return arr;//返回这个数组,也就是返回处理后的假数据
			})
			$.ajax({
				url:'http://www.bai.com',
				type:"PUSH",
				data:{
					id:1//假设需要添加id=1的数据
				},
				dataType:'json',
				success:function(a){
					console.log(a)
				}
			})

这是我从删除代码里面摸索出来的添加方法

模拟查找数据的接口

				var id = parseInt(options.body.split("=")[1])//获取id
				var index;
				for (var i in arr) {
					if(arr[i].id===id){//在数组arr里找到这个id
						arr[i].name = decodeURI(options.body.split("=")[2])//对body里面的进行解码其中后面的2是相对应data里面的数组长度
					}
				}
				return arr;//返回这个数组,也就是返回处理后的假数据
			})
			$.ajax({
				url:'http://www.bai.com',
				type:"post",
				data:{
					id:1,//假设需要编辑id=1的数据
					name:'我上去就是一个滑铲',
				},
				dataType:'json',
				success:function(a){
					console.log(a)
				}
			})

如果有什么不足,可以请各位大佬留言Thanks♪(・ω・)ノ。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值