微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

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

安装

rush:bash;"> npm install json-server -g

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

rush:plain;"> 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

rush:js;"> { "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,{ "id": 6,"link": "www.youhun.wang" }] }

在Mock目录下执行

rush:plain;"> 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的友链信息

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


什么是深拷贝与浅拷贝?深拷贝与浅拷贝是js中处理对象或数据复制操作的两种方式。‌在聊深浅拷贝之前咱得了解一下js中的两种数据类型:
前言 今天复习了一些前端算法题,写到一两道比较有意思的题:重建二叉树、反向输出链表每个节点 题目 重建二叉树: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列 {1,2,4,7,3,5,6,8} 和中序遍历序列 {
最近在看回JavaScript的面试题,this 指向问题是入坑前端必须了解的知识点,现在迎来了ES6+的时代,因为箭头函数的出现,所以感觉有必要对 this 问题梳理一下,所以刚好总结一下JavaScript中this指向的问题。
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面
如何用js控制图片放大缩小
JS怎么获取当前时间戳
JS如何判断对象是否为数组
JS怎么获取图片当前宽高