mockjs,json-server一起搭建前端通用的数据模拟框架教程


Posted in Javascript onDecember 18, 2017

无论是在工作,还是在业余时间做前端开发的时候,难免出现后端团队还没完成接口的开发,而前端团队却需要实现对应的功能,不要问为什么,这是肯定存在的。本篇文章就是基于此原因而产出的。希望对有这方面的需求的同志有所帮助。

一、使用的组件包

1. mockjs:用于模拟查询结果

2. json-server:搭建模拟服务器,以及模拟CRUD的相关操作接口

二、具体的实现1. 建立项目,并安装相应的依赖

cnpm install --save-dev mockjs json-server

上述命令为安装依赖,下图为项目结果:

mockjs,json-server一起搭建前端通用的数据模拟框架教程

说明:

data:此文件夹存放的为利用mockjs模拟的查询结果,dataProvider后面单独简单

lib:包含的一个jquery文件,用于模拟ajax请求用

route:json-server的路由表,用于模拟crud操作用,没搞清楚如何实现多个db.json

index.js:模拟服务器入口文件

test.html:测试cors

2. 搭建基础的json-server服务器

var JsonServer = require('json-server');
var path = require('path')

var Server = JsonServer.create();
var defaultMid = JsonServer.defaults({
 "noCors": false,
 "static": path.join(__dirname, "/lib")
});

var router = JsonServer.router(path.join(__dirname, '/route/db.json'));

Server.use(defaultMid);
Server.use(router);
Server.listen(8009);
console.log('start 8009.....');

此部分内容完全按照json-server的官方说明编写,值得注意的是static和noCors的设置,他是作为一个中间件来完成的。

3. 增加mockjs的应用

在这里mockjs只作为参生数据的基石,而dataProvider.js却提供了统一外部访问接口的能力。也就是把模拟数据以module(相当于mvc中的controller)和func(相当于mvc中的action)来进行分隔。不知这种实现是否可行(本人现在项目中暂时是这样使用的。)

3.1 首先,在data文件夹中建立emp.js文件,编写了如下内容:

 

var mockjs = require('mockjs');

module.exports = {
 list: function(){ 
 var data = mockjs.mock({
 'list|3':[
 {
  'id|+1':1
 }
 ]
 });
 return data.list;
 }
}

 此处就是对mockjs的使用

3.2 dataProvider使用实现模块的收集

var emp = require('./emp');

var moduels = {
 emp: emp
}

module.exports = {
 execute: function(m, f, args){
 return moduels[m][f].call(moduels[m], args);
 }
}

 3.3 json中增加get方法,用于获取数据

var provider = require('./data/dataProvider');

Server.get('/data',function(req,res){
 var moduleName = req.body ? req.body.moduleName : req.query.moduleName;
 var funName = req.body ? req.body.funName : req.query.funName;
 var arg = null;
 res.json(provider.execute(moduleName, funName));
 res.end();
});

如果要访问emp下的List,则地址为:http://localhost:8009/data?moduleName=emp&funName=list

4. 总结

1. json-server的db.json文件只能有一个,这里可以配置多个数据实体,他是以get为获取,post为写入http协议来实现数据的CRUD的

看到这里,你是否有感觉到搭建一个数据模拟服务器如此简单,当然只是webapi的。下载示例代码

以上这篇mockjs,json-server一起搭建前端通用的数据模拟框架教程就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
23个超流行的jQuery相册插件整理分享
Apr 25 Javascript
JS下拉框内容左右移动效果的具体实现
Jul 10 Javascript
JS获得图片alt信息的方法
Apr 01 Javascript
限制文本框只能输入数字||只能是数字和小数点||只能是整数和浮点数
May 27 Javascript
JavaScript+Java实现HTML页面转为PDF文件保存的方法
May 30 Javascript
BootStrap入门教程(二)之固定的内置样式
Sep 19 Javascript
JavaScript高仿支付宝倒计时页面及代码实现
Oct 21 Javascript
JS/HTML5游戏常用算法之追踪算法实例详解
Dec 12 Javascript
前端Electron新手入门教程详解
Jun 21 Javascript
微信小程序JS加载esmap地图的实例详解
Sep 04 Javascript
微信小程序使用蓝牙小插件
Sep 23 Javascript
微信小程序保持session会话的方法
Mar 20 Javascript
在knockoutjs 上自己实现的flux(实例讲解)
Dec 18 #Javascript
vue的无缝滚动组件vue-seamless-scroll实例
Dec 18 #Javascript
分析JavaScript数组操作难点
Dec 18 #Javascript
微信小程序基于本地缓存实现点赞功能的方法
Dec 18 #Javascript
JavaScript模块详解
Dec 18 #Javascript
webpack打包js文件及部署的实现方法
Dec 18 #Javascript
react+redux的升级版todoList的实现
Dec 18 #Javascript
You might like
php array的学习笔记
2012/05/16 PHP
解析phpstorm + xdebug 远程断点调试
2013/06/20 PHP
关于PHP语言构造器介绍
2013/07/08 PHP
不错的asp中显示新闻的功能
2006/10/13 Javascript
javascript offsetX与layerX区别
2010/03/12 Javascript
javascript针对DOM的应用分析(三)
2012/04/15 Javascript
基于datagrid框架的查询
2013/04/08 Javascript
JS继承--原型链继承和类式继承
2013/04/08 Javascript
为JS扩展Array.prototype.indexOf引发的问题探讨及解决
2013/04/24 Javascript
jquery动态增加text元素以及删除文本内容实例代码
2013/07/01 Javascript
微信开发 使用picker封装省市区三级联动模板
2016/10/28 Javascript
jQuery封装animate.css的实例
2018/01/04 jQuery
解决axios发送post请求返回400状态码的问题
2018/08/11 Javascript
vue+axios 前端实现的常用拦截的代码示例
2018/08/23 Javascript
vue动态添加路由addRoutes之不能将动态路由存入缓存的解决
2019/02/19 Javascript
[01:01:18]VP vs NIP 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
Python入门_浅谈for循环、while循环
2017/05/16 Python
酷! 程序员用Python带你玩转冲顶大会
2018/01/17 Python
在Python 2.7即将停止支持时,我们为你带来了一份python 3.x迁移指南
2018/01/30 Python
Pipenv一键搭建python虚拟环境的方法
2018/05/22 Python
pytorch训练imagenet分类的方法
2018/07/27 Python
Python cookie的保存与读取、SSL讲解
2020/02/17 Python
Django 自定义404 500等错误页面的实现
2020/03/08 Python
3种适用于Python的疯狂秘密武器及原因解析
2020/04/29 Python
Python DES加密实现原理及实例解析
2020/07/17 Python
全球立体声:World Wide Stereo
2018/09/29 全球购物
马来西亚户外装备商店:PTT Outdoor
2019/07/13 全球购物
C/C++有关内存的思考题
2015/12/04 面试题
德尔福集团DELPHI的笔试题
2012/02/22 面试题
迟到检讨书500字
2014/02/05 职场文书
社区精神文明建设汇报材料
2014/08/17 职场文书
竞聘自述材料
2014/08/25 职场文书
2015年教师新年寄语
2014/12/08 职场文书
2014年法务工作总结
2014/12/11 职场文书
读《儒林外史》有感:少一些功利,多一些真诚
2020/01/19 职场文书
Oracle设置DB、监听和EM开机启动的方法
2021/04/25 Oracle