使用json-server简单完成CRUD模拟后台数据的方法
在开发中,后端的接口往往是较晚出来的,但是有时候我们必须给前端页面一些虚假的数据去开发,这个时候一些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
新增
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) } })
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
javascript arguments 传递给函数的隐含参数
众所周知,js是脚本语言,脚本语言的一个特点就是极其灵活。有时“灵活”到使我这种习惯c系主流语言的人不得不佩服脚本的强大。比如这里要讲到的 arguments参数。2009-08-08深入理解JavaScript系列(15) 函数(Functions)
本章节我们要着重介绍的是一个非常常见的ECMAScript对象——函数(function),我们将详细讲解一下各种类型的函数是如何影响上下文的变量对象以及每个函数的作用域链都包含什么,以及回答诸如像下面这样的问题:下面声明的函数有什么区别么2012-04-04arcgis.js控制地图地体的显示范围超出区域自动弹回(实现思路)
这篇文章主要介绍了arcgis.js控制地图地体的显示范围超出区域自动弹回,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-01-01
最新评论