首页 > 其他分享 >json-server

json-server

时间:2023-07-23 19:07:11浏览次数:34  
标签:data server json api zhangpeiyue com scoreList

前端必备技能:json-server全攻略

在项目的初始阶段,后端提供的接口或数据可能是不完整的,作为一名前端开发工程师,不可避免的要使用mock的数据。如果此时的你不想使用简单的静态数据,而是想自己在本地启动一个server来模拟请求相关的操作,那么json-server是一个不错的选择。
json-serve可以帮助我们快速搭建一个mock-server本地服务,可以根据不同的后缀获取到不同的数据。
一、准备工作
1、安装Node
由于json-server需要通过Node对其进行启动,所以首先要安装Node。Node可自行安装,在此不再进行演示。
2、全局安装json-server
cnpm install json-server -g

3、查看版本
在cmd控制台中输入以下命令,查看版本号。用于验证是否安装成功。
json-server -v

4、准备一份JSON文件
我这里准备的是一份名字为score.json的文件,用于存放虚拟数据。
{  
    "scoreList":[    
            {"id":1,"userName":"张三","age":12,"sex":"男","score":{"yuWen":10,"shuXue":20,"yingYu":30}},    
            {"id":2,"userName":"李四","age":21,"sex":"女","score":{"yuWen":12,"shuXue":45,"yingYu":37}},    
            {"id":3,"userName":"王五","age":56,"sex":"男","score":{"yuWen":12,"shuXue":20,"yingYu":30}},    
            {"id":4,"userName":"赵六","age":23,"sex":"女","score":{"yuWen":19,"shuXue":21,"yingYu":65}},    
            {"id":5,"userName":"严七","age":12,"sex":"男","score":{"yuWen":34,"shuXue":67,"yingYu":43}},    
            {"id":6,"userName":"沈八","age":43,"sex":"女","score":{"yuWen":56,"shuXue":76,"yingYu":30}},    
            {"id":7,"userName":"钱九","age":13,"sex":"男","score":{"yuWen":24,"shuXue":89,"yingYu":30}},    
           {"id":8,"userName":"张十","age":12,"sex":"女","score":{"yuWen":10,"shuXue":54,"yingYu":31}}  
     ]
}

二、启动服务
1、常用命令选项:
•-- watch:通过该命令可以实时监测score.json的变化,如果省略该命令,即使score.json发生变化,刷新、或重新发送请求,
仍然会返回初次启动服务时的数据。简写形式为:-w•--port:指定服务的端口号,可省略,默认为3000。简写形式:-p•--host:设置域,可省略。简写形式:-H
json-server --watch score.json --port 8090  --host 127.0.0.1
上方命令可简写为:
json-server score.json -w -p 8090 -H 127.0.0.1
但,一般通过下面命令,即可完基本工作:
json-server -w score.json

2、工作场景建议
如果你已知项目接口域名及端口号,为避免后续更改接口信息。我们可以这样做:
1、假设项目接口域名为:api.zhangpeiyue.com,端口号为:80
2、设置host映射:用记事本打开C:\Windows\System32\drivers\etc目录中的hosts文件。
底部增加:127.0.0.1 api.zhangpeiyue.com,该文件如果不允许修改,增加相对应的权限即可。
•启动服务命令:
json-server --watch score.json --port 80  --host api.zhangpeiyue.com
由于80是默认端口号,所以我们可以通过api.zhangpeiyue.com来对数据进行操作了。
3、通过package.json文件启动项目
启动json-server时, 如果自定义配置的参数过多,容易出现命令敲错的现象。我们可以在创建一个名字为package.json的文件,内容为:
{  "scripts": {    "score": "json-server --watch score.json --port 80  --host api.zhangpeiyue.com"  }}
通过npm run score启动即可。

4、自定义配置文件
json-server允许我们把所有的配置放到一个配置文件中,这个配置文件默认json-server.json。配置文件的主要内容如下:
{  
    "port": 80,  // 自定义服务监听端口  
    "watch": true, // 服务监听  
    "host": "api.zhangpeiyue.com",// 指定域  
    "static": "./public", // 静态文件目录,可以将项目的HTML,JS,IMG等资源放在这里  
    "read-only": false,  // 是否只允许get请求  
    "no-cors":false, // 是否允许跨域访问  
    "no-gzip": false, // 是否可压缩  
    "routes": "route.json" // 自定义路由,这个配置可以暂时省略,后续会有所涉及
}
可以通过json-server --watch score.json启动项目。

4、输出类似以下内容,说明启动成功。
5、其它相关启动参数
三、获取数据(get)
1、get获取scoreList属性
•http://api.zhangpeiyue.com/scoreList
(async ()=>{    const {data} = await axios.get("http://api.zhangpeiyue.com/scoreList");    console.log(data);})();

2、通过以下两种方式可get获取scoreList属性当中id为1的数据:
•http://api.zhangpeiyue.com/scoreList/1
(async ()=>{    const {data} = await axios.get("http://api.zhangpeiyue.com/scoreList/1");    console.log(data);})();
•http://api.zhangpeiyue.com/scoreList?id=1
(async ()=>{    const {data} = await axios.get("http://api.zhangpeiyue.com/scoreList",{        params:{            id:1        }    });    console.log(data);})();

3、单条件查找:scoreList属性author为李四的数据
•http://api.zhangpeiyue.com/scoreList?userName=李四
(async ()=>{    const {data} = await axios.get("http://api.zhangpeiyue.com/scoreList",{        params:{            userName:"李四"        }    });    console.log(data);})();

4、多条件查找:scoreList属性sex为男,age为12的数据
•http://api.zhangpeiyue.com/scoreList?sex=男&age=12
(async ()=>{    const {data} = await axios.get("http://api.zhangpeiyue.com/scoreList",{        params:{            sex:"男",            age:12        }    });    console.log(data);})();

5、q全局搜索(模糊查询):查询scoreList所有属性值中包含英的数据
•http://api.zhangpeiyue.com/scoreList?q=张
(async ()=>{    const {data} = await axios.get("http://api.zhangpeiyue.com/scoreList",{        params:{            q:"张"        }    });    console.log(data);})();

6、可以用.访问更深层的属性:查询scoreList属性score的属性yuWen为12的数据:
•http://api.zhangpeiyue.com/scoreList?roles.yuWen=12
(async ()=>{    const {data} = await axios.get("http://api.zhangpeiyue.com/scoreList",{        params:{            ["score.yuWen"]:12        }    });    console.log(data);})();

7、通过_page and _limit 实现对数据的分页:将scoreList每页显示3条记录,查询第2页内容:
•http://api.zhangpeiyue.com/scoreList?_page=2&_limit=3
(async ()=>{    const {data} = await axios.get(" http://api.zhangpeiyue.com/scoreList",{        params:{            _page:2,            _limit:3        }    });    console.log(data);})();

8、通过_sort与_order 对数据进行排序。_sort指定排序的属性,_order指定排序的类型(asc为升序,desc为降序)
•按age的倒序排列: http://api.zhangpeiyue.com/scoreList?_sort=age&_order=desc
(async ()=>{    const {data} = await axios.get("http://api.zhangpeiyue.com/scoreList",{        params:{            _sort:"age",            _order:"desc"        }    });    console.log(data);})();

•多条件排序:年龄相同按语文的升序排列: http://api.zhangpeiyue.com/scoreList?_sort=age,score.yuWen&_order=desc,asc
(async ()=>{    const {data} = await axios.get("http://api.zhangpeiyue.com/scoreList",{        params:{            _sort:"age,score.yuWen",            _order:"desc,asc"        }    });    console.log(data);})();

9、通过_start、_end、_limit对数据进行截取。
•截取前5条记录: http://api.zhangpeiyue.com/scoreList?_limit=5
(async ()=>{    const {data} = await axios.get("http://api.zhangpeiyue.com/scoreList",{        params:{            _limit:5        }    });    console.log(data);})();

•截取第3到第6的记录(共三条): http://api.zhangpeiyue.com/scoreList?_start=3&_end=6
(async ()=>{    const {data} = await axios.get("http://api.zhangpeiyue.com/scoreList",{        params:{            _start:3,            _end:6        }    });    console.log(data);})();

•从第2条记录开始截取5条记录(共5条): http://api.zhangpeiyue.com/scoreList?_start=2&_limit=5
(async ()=>{    const {data} = await axios.get("http://api.zhangpeiyue.com/scoreList",{        params:{            _start:2,            _limit:5        }    });    console.log(data);})();

10、通过操作符_gte(大于等于), _lte(小于等于), _ne(不等于), _like(模糊查询)获得数据。
•年龄大于等于23: http://api.zhangpeiyue.com/scoreList?age_gte=23
(async ()=>{    const {data} = await axios.get("http://api.zhangpeiyue.com/scoreList",{        params:{            age_gte:23        }    });    console.log(data);})();
* `http://api.zhangpeiyue.com/scoreList?age_gte=23`(async () => {    const {data} = await axios.post("http://api.zhangpeiyue.com/scoreList", {        "id": 11,        "userName": "萧十一郎",        "age": 28,        "sex": "男",        "score": {"yuWen": 100, "shuXue": 100, "yingYu": 100}    });    console.log(data);})();

五、删除数据(delete)
•删除id为11的数据: http://api.zhangpeiyue.com/scoreList/11
(async () => {    const {data} = await axios.delete("http://api.zhangpeiyue.com/scoreList/11");    console.log(data);})();
六、更新数据(patch、put)
•通过patch请求,将id为8的记录属性userName修改为张八。(patch为局部修改) http://api.zhangpeiyue.com/scoreList/8
(async () => {    const {data} = await axios.patch("http://api.zhangpeiyue.com/scoreList/8",{        userName:"张八"    });    console.log(data);})();
•通过put请求将id为8的记录替换成一个新的对象,该对象只有userName属性,值为新来的。(put为替换,id不会替换) http://api.zhangpeiyue.com/scoreList/8
(async () => {    const {data} = await axios.put("http://api.zhangpeiyue.com/scoreList/8",{        userName:"新来的"    });    console.log(data);})();

七、自定义路由
创建route.json文件,可对路由进行如下配置:
{//    /data/data1  ==>  /data1    "/data/*": "/$1",//    /data1/001/show ==> /data1/001    "/:resource/:id/show": "/:resource/:id",//    /data1/Sherry ==> /data1?name=Sherry    "/data1/:name": "/data1?name=:name",//    /data1?id=002 ==> /data/002     "/:anyArray\\?id=:id": "/:anyArray/:id"}
启动:
json-server --watch score.json --routes route.json

八、json-server是依赖express开发而来,如有需要可进行深度定制
1、安装json-server
cnpm install json-server -D
2、创建server.js文件:
const jsonServer = require('json-server');const $db = require(__dirname+"/score.json"); const server = jsonServer.create();const middlewares = jsonServer.defaults();const router = jsonServer.router($db);server.use(router);server.use(middlewares);server.use(jsonServer.bodyParser);server.listen(8090, () => {    console.log('success');});


学到了学到了,这两天正在做这个,现在思路更清晰了。

标签:data,server,json,api,zhangpeiyue,com,scoreList
From: https://blog.51cto.com/u_16103408/6827349

相关文章

  • python将xml文件转换为json
    转载自:如何使用Python实现XML转JSON-知乎(zhihu.com)代码:importosimportjsonimportxmltodictdefxml_to_JSON(xml):#格式转换try:convertJson=xmltodict.parse(xml,encoding='utf-8')jsonStr=json.dumps(convertJson,indent=1)......
  • C#解析匿名JSON数据
    C#解析匿名JSON数据使用工具:Newtonsoft.Json使用方式://模拟数据varjsonData=JsonConvert.SerializeObject(new{Name="张三",Id=1,Age=18,UserName="123123"});JObjectjObject=JObject.Parse(jsonData);//解析数据varname=jObject["Name"......
  • SQL Server 的网络通信机制
    问题我试图了解SQLServer如何在网络上进行通信,因为我必须告诉我的网络团队在防火墙上打开哪些端口,以便边缘Web服务器与内部的SQLServer进行通信。我需要知道什么? 解决方案为了了解需要在哪里打开什么,我们首先简单谈谈当今常用的两个主要协议:TCP-传输控制协议UDP......
  • 解决无法打开到 SQL Server 的连接错误
    一、问题描述有时,您可能会在连接到SQLServer时遇到问题,并且可能会收到如下消息: 这些错误可能是针对 命名管道连接或 TCP/IP连接。在本技巧中,我们将探讨导致这些错误的原因以及解决方法。二、解决方案您收到这些错误消息的原因可能有多种。请按照以下步骤查看是否可......
  • python 转 json []
    Python转JSON[]1.流程下面是将Python转换为JSON[]的整个流程:步骤描述1创建一个Python对象2使用json模块的dumps()方法将Python对象转换为JSON字符串3使用json模块的loads()方法将JSON字符串转换为Python对象2.代码实现步骤......
  • python 输出json文件
    Python输出JSON文件详解在Python中,我们可以使用json模块来处理JSON数据。JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式,常用于将数据从一个系统传输到另一个系统。在本文中,我们将学习如何使用Python输出JSON文件。什么是JSON文件?JSON是一种用于存储和交换数据的格......
  • MySQL中使用JSON存储数据
    1.概述:MySQL从5.7版本开始引入了对JSON数据类型的原生支持。这个增强功能使开发人员能够直接在数据库中存储、操作和查询JSON数据。MySQL的JSON字段为存储半结构化数据提供了更加灵活和高效的方式。相比传统的关系型数据库,使用JSON字段的优势包括:灵活性:JSON字段可以存储不同......
  • python如何判断json中是否有某个字段
    项目方案:检查JSON中是否存在某个字段1.项目概述本项目旨在开发一个Python库,用于检查JSON数据中是否存在某个字段。通过对JSON数据进行解析和遍历,我们能够快速判断给定的字段是否存在于JSON中。2.项目需求用户能够将JSON数据作为输入,指定要查找的字段名称。程序能够遍历JSON......
  • sql server 大数据复制到另一张表
    SQLServer大数据复制到另一张表在日常的数据库操作中,我们经常需要将一个表中的数据复制到另一个表中,这在数据分析、数据备份等场景下非常常见。本文将介绍如何使用SQLServer将一个表中的大量数据复制到另一个表中,同时提供相应的代码示例。1.创建目标表首先,我们需要在数据......
  • spark开启historyserver
    Spark开启HistoryServer简介在使用ApacheSpark进行大数据处理时,我们常常需要查看作业的执行历史和性能指标。Spark提供了一个称为HistoryServer的组件,它能够保存和展示Spark应用程序的执行历史数据。本文将介绍如何开启Spark的HistoryServer,并提供详细的步骤和代码示例。步......