博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用 json-server 简单完成CRUD模拟后台数据
阅读量:6190 次
发布时间:2019-06-21

本文共 2723 字,大约阅读时间需要 9 分钟。

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

安装

npm install json-server -g复制代码

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

json-server [options] 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

新增

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

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

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

修改

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

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

删除

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

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

转载地址:http://otrda.baihongyu.com/

你可能感兴趣的文章
web.xml/servlet过滤器之压缩UrlRewriteFilter
查看>>
redis的持久化(RDB&AOF的区别)
查看>>
8.Kubernetes Service(服务)
查看>>
Asp.Net Core 发布和部署(Linux + Jexus )
查看>>
swift 全局常量 && 全局变量的写法
查看>>
Creating A Second Instance of the IPS Repository Server With SMF
查看>>
iOS开发库的族“.NET研究”谱介绍
查看>>
对二进制补码的理解<转>
查看>>
图解DevExpress RichEditControl富文本的使用,附源码及官方API
查看>>
ubuntu 学习笔记
查看>>
BNU 34986 Football on Table
查看>>
三级联动---城市地区选择
查看>>
闪回flashback#ocp试验#
查看>>
webpack插件html-webpack-plugin
查看>>
软件设计的复杂度
查看>>
无法从使用方法中推导出方法... 的类型实參,请尝试显式指定类型实參
查看>>
axios学习笔记
查看>>
Git各种错误操作撤销的方法
查看>>
剖析 Laravel 计划任务--避免重复
查看>>
公司框架遇到的问题
查看>>