使用 json-server 简单完成CRUD模拟后台数据
本文于2221天之前发表,文中内容可能已经过时。
在开发中,后端的接口往往是较晚出来的,但是有时候我们必须给前端页面一些虚假的数据去开发,这个时候一些mock工具就很有必要了,最终我选择了json server
工具,因为它足够简单,而且也能和你们所熟知的Mock.js 配合模拟数据(思考:mockjs是可以作为一个独立的mock server
存在,但为什么不单独用它?)。
安装
1 | npm install json-server -g |
安装完成后可以用 json-server -h
命令检查是否安装成功。
1 | json-server [options] <source> |
使用
创建个Mock
目录,在该目录下创建一个json文件,db.json
1 | { |
在Mock目录下执行
1 | 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
工具,最后一条删除我使用jquer的$.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的友链信息
1 | $.ajax({ |