使用mock.js随机数据和使用express输出json接口的实现方法


Posted in Javascript onJanuary 07, 2018

前端项目都会用到后端的接口,但当后台接口没有写好的时候,这时候可以用mock.js先随机生成一些假数据来调试页面

安装mock.js

先用express创建一个nodejs的web项目,名字假如是 demo ,这里就不说了

yarn add mockjs

使用

const Mock = require('mockjs')

var data = Mock.mock({
 'list|2': [{
 'id|+1': 1,
 'color': '@color()',
 'date': '@datetime()',
 'img': '@image()',
 'url': '@url(http)',
 'email': '@email()',
 'name': "@name(1,2)",
 'text': '@paragraph()'
 }]
})
console.log(JSON.stringify(data))

上面的随机方法在最下面给出的mockjs文档的链接里可以找到,Mock.Random调用的方法,直接拿来在前面加上@就可以用了,非常方便

输出

{
 "list": [
 {
  "id": 1,
  "color": "#8179f2",
  "date": "2015-06-22 12:10:08",
  "img": "http://dummyimage.com/250x250",
  "url": "http://hwujcvh.fk/vfrjfmi",
  "email": "y.ahbatuekk@mbkhfybrh.pl",
  "name": "James Ronald Rodriguez",
  "text": "Zsogshtw qjscoe qwggnfk ppbdpqd avftd pvczrvnu gsyfyefm rbnbjyy tgemy buple ieghyjp klcxauofu lhjmnb kjpyodk. Njync ysrvx jevei stawy mcosrlpo iacryqob wkkcfuh nkrrdutr zduikjvtf dcv pppbhi ygjnkmg xvpusp ayu lvu. Wgqmtwvo ibqzp cct kodyh ovz slo cpc uqaseuwv ubjgbf hihh oudly mooztiojpi tubmwhsmb kktbkyqp hsvwgoluu jrkosqudm. Wpumdvtw riytwoa sbittrr xtjy beorkb osnjpigntu ndrgxhozeq iufhu hpuirgmh lstoijpqx hopk lkxceqhvr uymj pgdms njjmu ivxijmokn."
 },
 {
  "id": 2,
  "color": "#94f279",
  "date": "1980-02-20 19:46:44",
  "img": "http://dummyimage.com/336x280",
  "url": "http://voyqj.cx/jjyksqzur",
  "email": "k.ydgui@gixl.cr",
  "name": "Ronald Nancy Harris",
  "text": "Lbdpwqwpgd sodipqu oncnnyis ebtwho dnbt fqxnjyzr qtrriop gfbjt prto dgmtgff gwaqnhon sdlvpxpj pqomfflsc skj. Cvteunoj oqmjnfm vowvmw ypywtr klcazkvg cvsyzayytl bgvywe kfqqzhfg iahm jwury xsgf xnr pvfxwhaed nauookwi xuxtgnwq flcbmnrm qglgziy vegml. Cexit vdotefuj nptmei hekmljnt bukxrd ndhj lkfyjcv oldpgo rrj kprfklt nfks yvrvc. Aynbyd hxguza ftjrn kmlirqo wxald jqjkvahim jnhezpgm usev qbynwhm yotehgkwdg eyxj vfnm icchnds dgmd odxajing vqrdl yhpp eba. Tykxnhe njod bslwbsjcj rwlv rkvxk rypew fpfqrqi psislxuwgs jcwrbtfn qeszy leovhc jwupwzo kitct nhbdhjq xyiajxms. Gfgkw nnlg drcqnpwn bowqknwy oiw yysaohk fqqsbgvp mulik vusikwv nbp kpbo nhti dhf hrgql."
 }
 ]
}

集成到express里输出json

const Mock = require('mockjs')

exports.index = function(req, res) {
 var data = Mock.mock({
 'list|2': [{
  'id|+1': 1,
  'color': '@color()',
  'date': '@datetime()',
  'img': '@image()',
  'url': '@url(http)',
  'email': '@email()',
  'name': "@name(1,2)",
  'text': '@paragraph()'
 }]
 })
 // 延时1秒,模拟网络请求时间
 setTimeout(function() {
 res.send(JSON.stringify(data))
 }, 1000);
}

express跨域

接口地址跟前端项目地址肯定会不一样,这时候请求接口就会涉及到跨域的问题,express里的解决办法如下

app.all('*', function(req, res, next) {
 res.header("Access-Control-Allow-Origin", "http://localhost:8080");
 res.header("Access-Control-Allow-Headers", "X-Requested-With");
 res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");
 res.header("X-Powered-By",' 3.2.1')
 res.header("Content-Type", "application/json;charset=utf-8");
 res.header('Access-Control-Allow-Credentials', true);
 next();
});

说明:上面代码是在网上找的,不过网上找的没有这句 res.header('Access-Control-Allow-Credentials', true);

我前端项目的地址是 http://localhost:8080 所以 Access-Control-Allow-Origin 的值就是 http://localhost:8080

可以根据自己的服务器来修改

参考

•mockjs文档

总结

以上所述是小编给大家介绍的使用mock.js随机数据和使用express输出json接口的实现方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
让浏览器非阻塞加载javascript的几种方法小结
Apr 25 Javascript
node.js中的fs.chmodSync方法使用说明
Dec 18 Javascript
深入理解JavaScript系列(28):设计模式之工厂模式详解
Mar 03 Javascript
详解iframe与frame的区别
Jan 13 Javascript
Javascript基础_简单比较undefined和null 值
Jun 14 Javascript
AngularJS 自定义指令详解及示例代码
Aug 17 Javascript
javascript 网页进度条简单实例
Feb 22 Javascript
微信小程序实战之顶部导航栏(选项卡)(1)
Jun 19 Javascript
用javascript获取任意颜色的更亮或更暗颜色值示例代码
Jul 21 Javascript
angularjs实现猜数字大小功能
May 20 Javascript
Three.js利用Detector.js插件如何实现兼容性检测详解
Sep 26 Javascript
实例解析Vue.js下载方式及基本概念
May 11 Javascript
使用 Node.js 开发资讯爬虫流程
Jan 07 #Javascript
CentOS环境中MySQL修改root密码方法
Jan 07 #Javascript
12条写出高质量JS代码的方法
Jan 07 #Javascript
js数组方法reduce经典用法代码分享
Jan 07 #Javascript
javascript中的replace函数(带注释demo)
Jan 07 #Javascript
基于JavaScript实现简单的音频播放功能
Jan 07 #Javascript
js实现复制功能(多种方法集合)
Jan 06 #Javascript
You might like
Syphon 秘笈
2021/03/03 冲泡冲煮
PHP安全编程之加密功能
2006/10/09 PHP
YII Framework框架教程之使用YIIC快速创建YII应用详解
2016/03/15 PHP
PHP实现链式操作的三种方法详解
2017/11/16 PHP
JavaScript sup方法入门实例(把字符串显示为上标)
2014/10/20 Javascript
js 通过cookie实现刷新不变化树形菜单
2014/10/30 Javascript
简单谈谈jQuery(function(){})与(function(){})(jQuery)
2014/12/19 Javascript
NodeJS学习笔记之Connect中间件应用实例
2015/01/27 NodeJs
JS使用cookie实现DIV提示框只显示一次的方法
2015/11/05 Javascript
jQuery实现鼠标跟随提示层效果代码(可显示文本,Div,Table,Html等)
2016/04/18 Javascript
深入浅析JavaScript的API设计原则
2016/06/14 Javascript
bootstrap中使用google prettify让代码高亮的方法
2016/10/21 Javascript
javascript实现获取指定精度的上传文件的大小简单实例
2016/10/25 Javascript
js 单引号替换成双引号,双引号替换成单引号的实现方法
2017/02/16 Javascript
利用Promise自定义一个GET请求的函数示例代码
2019/03/20 Javascript
javascript实现5秒倒计时并跳转功能
2019/06/20 Javascript
jQuery 选择器用法实例分析【prev + next】
2020/05/22 jQuery
addEventListener()和removeEventListener()追加事件和删除追加事件
2020/12/04 Javascript
在vue项目中封装echarts的步骤
2020/12/25 Vue.js
vue常用高阶函数及综合实例
2021/02/25 Vue.js
Python功能键的读取方法
2015/05/28 Python
浅谈Python的异常处理
2016/06/19 Python
面向初学者的Python编辑器Mu
2018/10/08 Python
Python3爬虫学习之应对网站反爬虫机制的方法分析
2018/12/12 Python
简单了解python元组tuple相关原理
2019/12/02 Python
基于python SMTP实现自动发送邮件教程解析
2020/06/02 Python
Python配置pip国内镜像源的实现
2020/08/20 Python
python反扒机制的5种解决方法
2021/02/06 Python
牵手50香港:专为黄金岁月的单身人士而设的交友网站
2020/08/14 全球购物
财会专业毕业生自荐信
2014/07/09 职场文书
优秀班主任先进事迹材料
2014/12/16 职场文书
婚礼长辈答谢词
2015/09/29 职场文书
历史名人教你十五个读书方法,赶快Get起来!
2019/07/18 职场文书
创业项目大全(适合在家创业的项目)
2019/08/15 职场文书
用Python简陋模拟n阶魔方
2021/04/17 Python
SQL Server 中的事务介绍
2022/05/20 SQL Server