Node(Express):http://www.expressjs.com.cn
jquery等
无数据库的情况下,实现数据持久化,通过api url
返回json
数据,提高前端开发效率!
- 完整的操作页面
- 首页展示所有保存的接口列表
- 创建的接口保存到本地或线上
- 支持重新编辑
- 编辑过程实时预览和错误提示
- 根据接口名称或者url进行检索
- 提供url跨域调用
- 接口更新及删除
前端开发工作中一个重头戏就是和后台实现数据交互。 很多前端入门不久的同学在涉及到和后台交互的时候,都需要等待后端开发做好,给了数据才可以继续,就是所谓的串行开发。
实际上我们并不需要等后台开发完成,只要一开始的时候双方约定好数据格式,前端自己模拟一些数据就可以投入工作,这样就可以并行开发,效率可以显著提高
上面的问题可以有多种解决方案
-
直接代码里面js本地或线上造数据
... var data = {...} ... //这种方案适合小型结构的数据,一旦数据过于庞大,不适合放在js文件里面,不利于维护 //不能很好的模拟ajax $.ajax({ url:'..'//这个时候ajax接口不存在,调不通 }) //不能重复利用,上生产肯定要删掉
-
使用mockjs:http://mockjs.com 生成随机数据,拦截 Ajax 请求 这个网上有丰富的介绍,可以直接百度
本文介绍了一个简单的平台化方案,创建一个本地或线上化的服务系统,你也可以把它布到线上,用于相应的http或https服务,这样得到数据格式之后,本地或线上生成一个可用的 url
用于ajax
请求,而且还可以让数据持久化,如果放在局域网内,接口还可以共享给小伙伴。
说到持久化,那么必须涉及到数据的存储,用于存储的数据库有很多,我以前用过mongodb
结合Node.js
使用,也是蛮好的,但是数据库安装也蛮麻烦的,我们这里有一个更简便的,硬盘本身就是一个“数据库”
,所以我们可以使用Node.js
的fs
模块直接创建json
文件,读取json
文件。这样创建的每一个json
文件都对于一个接口服务,只要不删除,就可以一直重复利用。
github
下载源码:git clone git@github.com:PhotoArtLife/jsonServer.git 并执行npm install
安装(cnpm有的时候也有坑,不过还是凑合着用)
安装:npm install -g cnpm --registry=https://registry.npm.taobao.org
cnpm install(安装所有依赖模块)
- 启动node服务(两种方式),
node start
或pm2 start server.json
(前者会合并命令,自动执行pm2 start app.js)
备注: 本项目中用到一款利器:pm2—管理Node.js应用,生产环境进程管理工具(进程守护工具),用来在生产/开发环境中进行自动重启、日志记录、错误预警等等; 启动:(支持进程一直运行,除非你执行pm2 stop appid或pm2 delete appid等杀掉进程) 3. 打开首页 http://localhost:3002/或http://你的域名/端口号(https://你的域名/端口号),建议用chrome访问
-
点击创建接口,
API
名称用来描述接口左右,API url
用来调用数据,都是必填。如图,我们创建一个接口testapi
可以实时预览json格式,可以快速定位格式错误。也可以借助网上更多的格式化工具。创建完成点击最下面的保存按钮,提示保存成功就完成了接口的创建!
-
使用接口,根据刚刚创建的
url:testapi
生成一个链接 http://localhost:3002/getjson/testapi 可以在控制台调用一下这个url
可以看出就是我们刚刚存储的json
数据。 -
搜索功能:在搜索框输入接口中文描述名称或者
apiurl
的名称即可。 -
注意:
ajaxapilist.json
存着一张关系表,对应所有的接口描述名称和url
,用于查询,建议不要修改,
二次开发,作为学习node的笔记
备注:来自阿里云/个人驿站:http://kquanr.com