使用json-server简单完成CRUD模拟后台数据的方法


Posted in Javascript onJuly 12, 2018

在开发中,后端的接口往往是较晚出来的,但是有时候我们必须给前端页面一些虚假的数据去开发,这个时候一些mock工具就很有必要了,最终我选择了 json server 工具,因为它足够简单,而且也能和你们所熟知的Mock.js 配合模拟数据(思考:mockjs是可以作为一个独立的 mock server 存在,但为什么不单独用它?)。

安装

npm install json-server -g

安装完成后可以用 json-server -h 命令检查是否安装成功。

json-server [options] <source>

Options:
 --config, -c    指定 config 文件         [默认: "json-server.json"]
 --port, -p     设置端口号                  [default: 3000]
 --host, -H     设置主机                  [默认: "0.0.0.0"]
 --watch, -w    监控文件                      [boolean]
 --routes, -r    指定路由文件
 --static, -s    设置静态文件
 --read-only, --ro 只允许 GET 请求                  [boolean]
 --no-cors, --nc  禁止跨域资源共享                  [boolean]
 --no-gzip, --ng  禁止GZIP                     [boolean]
 --snapshots, -S  设置快照目录                   [默认: "."]
 --delay, -d    设置反馈延时 (ms)
 --id, -i      设置数据的id属性 (e.g. _id)           [默认: "id"]
 --quiet, -q    不输出日志信息                   [boolean]
 --help, -h     显示帮助信息                    [boolean]
 --version, -v   显示版本号                     [boolean]

使用

创建个 Mock 目录,在该目录下创建一个json文件, db.json

{
 "list": [
 {
  "name": "游魂博客",
  "link": "www.iyouhun.com",
  "id": 1
 },
 {
  "id": 2,
  "name": "买卖淘",
  "link": "www.868432.net"
 },
 {
  "id": 3,
  "name": "游魂全自动网页制作系统",
  "link": "www.youhun.wang"
 },
 {
  "id": 4,
  "name": "游魂博客",
  "link": "www.iyouhun.com"
 },
 {
  "id": 5,
  "name": "买卖淘",
  "link": "www.868432.net"
 },
 {
  "id": 6,
  "name": "游魂全自动网页制作系统",
  "link": "www.youhun.wang"
 }]
}

在Mock目录下执行

json-server db.json

打开浏览器, http://localhost:3000 ,查看页面。可以试着直接访问他索引出来的资源 如果要监控json文件的变化,启动的时候加上参数 --watch 或者 -w 。

支持的方法

你可以使用任何 HTTP method

如:

  • GET /list 获取列表
  • GET /list/1 获取id=1的数据
  • POST /list 创建一个项目
  • PUT /list/1 更新一个id为1的数据
  • PATCH /list/1 部分更新id为1的数据
  • DELETE /list/1 删除id为1的数据

注意:

  • 当你发送POST,PUT,PATCH 或者 DELETE请求时,变化会自动安全的保存到你的db.json文件中。
  • 你的请求体body应该是封闭对象。比如{"name": "Foobar"}
  • id不是必须的,在PUT或者PATCH方法中,任何的id值将会被忽略。
  • 在POST请求中,id是可以被添加的,如果该值没有没占用,会使用该值,否则自动生成。
  • POST,PUT或者PATCH请求应该包含一个Content-Type:application/json的header,来确保在请求body中使用json。

操作数据

这里请求数据我全部使用postman工具,最后一条删除我使用jquery的$.ajax  举例

查询

GET请求:http://localhost:3000/list

使用json-server简单完成CRUD模拟后台数据的方法

新增

POST请求:http://localhost:3000/list

参数:{"name":"游魂博客","link":www.iyouhun.com}

使用json-server简单完成CRUD模拟后台数据的方法

请求成功后会看到返回的就是新增成功的友链信息

修改

PUT请求:http://localhost:3000/list/1  修改id为1的友链信息

参数:{"name":"哈哈哈哈哈客","link":"www"}

使用json-server简单完成CRUD模拟后台数据的方法

删除

DELETE请求:http://localhost:3000/list/1 删除id为1的友链信息

$.ajax({
  type: 'DELETE',
  url: 'http://localhost:3000/list/1',
  success: function (data) {
    console.log(data)
  }
})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
一个很简单的jquery+xml+ajax的无刷新树结构(无css,后台是c#)
Jun 02 Javascript
Javascript学习笔记之 函数篇(一) : 函数声明和函数表达式
Jun 24 Javascript
javascript搜索框点击文字消失失焦时文本出现
Sep 18 Javascript
JavaScript随机生成信用卡卡号的方法
Apr 07 Javascript
JS中dom0级事件和dom2级事件的区别介绍
May 05 Javascript
微信小程序 MINA文件结构
Oct 17 Javascript
AngularJS报错$apply already in progress的解决方法分析
Jan 30 Javascript
BootStrap Select清除选中的状态恢复默认状态
Jun 20 Javascript
利用Console来Debug的10个高级技巧汇总
Mar 26 Javascript
vue-cli 引入、配置axios的方法
May 08 Javascript
JS+CSS3实现的简易钟表效果示例
Apr 13 Javascript
小程序实现横向滑动日历效果
Oct 21 Javascript
教你如何用node连接redis的示例代码
Jul 12 #Javascript
angular 内存溢出的问题解决
Jul 12 #Javascript
详解vue填坑之解决部分浏览器不支持pushState方法
Jul 12 #Javascript
vue插件开发之使用pdf.js实现手机端在线预览pdf文档的方法
Jul 12 #Javascript
vue中如何实现pdf文件预览的方法
Jul 12 #Javascript
js+css实现红包雨效果
Jul 12 #Javascript
基于vue cli 通过命令行传参实现多环境配置
Jul 12 #Javascript
You might like
一个php作的文本留言本的例子(一)
2006/10/09 PHP
关于在php.ini中添加extension=php_mysqli.dll指令的说明
2007/06/14 PHP
php实现异步数据调用的方法
2015/12/24 PHP
浅谈php中的访问修饰符private、protected、public的作用范围
2016/11/20 PHP
浅谈PHP的exec()函数无返回值排查方法(必看)
2017/03/31 PHP
用javascript实现自定义标签
2007/05/08 Javascript
jQuery代码优化 事件委托篇
2011/11/01 Javascript
JS常见问题整理(持续更新)
2013/08/06 Javascript
Ext JS 4实现带week(星期)的日期选择控件(实战二)
2013/08/21 Javascript
JS调试必备的5个debug技巧
2014/03/07 Javascript
Visual Studio中js调试的方法图解
2014/06/30 Javascript
jQuery中hide()方法用法实例
2014/12/24 Javascript
jQuery Validate初步体验(一)
2015/12/12 Javascript
jQuery实现响应鼠标事件的图片透明效果【附demo源码下载】
2016/06/16 Javascript
javascript js 操作数组 增删改查的简单实现
2016/06/20 Javascript
基于Layer+jQuery的自定义弹框
2020/05/26 Javascript
JQuery学习总结【一】
2016/12/01 Javascript
EasyUI学习之Combobox下拉列表(1)
2016/12/29 Javascript
bootstrap表单按回车会自动刷新页面的解决办法
2017/03/08 Javascript
vue2组件之select2调用的示例代码
2017/10/12 Javascript
详解vue项目接入微信JSSDK的坑
2018/12/14 Javascript
用Javascript实现发送短信验证码间隔功能
2021/02/08 Javascript
python调用cmd复制文件代码分享
2013/12/27 Python
浅谈python 中类属性共享的问题
2019/07/02 Python
pytorch方法测试——激活函数(ReLU)详解
2020/01/15 Python
解决Python中报错TypeError: must be str, not bytes问题
2020/04/07 Python
在Ubuntu 20.04中安装Pycharm 2020.1的图文教程
2020/04/30 Python
HTML5组件Canvas实现图像灰度化(步骤+实例效果)
2013/04/22 HTML / CSS
美国领先的在线邮轮旅游公司:CruiseDirect
2018/06/07 全球购物
违纪检讨书2000字
2014/02/08 职场文书
会议主持人开场白台词
2015/05/28 职场文书
2016年国陪研修感言
2015/11/18 职场文书
2019年行政人事个人工作总结范本!
2019/07/19 职场文书
Vue vee-validate插件的简单使用
2021/06/22 Vue.js
java设计模式--建造者模式详解
2021/07/21 Java/Android
Go语言实现一个简单的并发聊天室的项目实战
2022/03/18 Golang