聊聊JSON Schema

更新日期: 2019-03-12 阅读: 4.2k 标签: json

简介

json现在已经成为比较通用灵活的数据交换格式,尤其是在web方面,总是少不了它的身影,js原生就支持它。网页中与服务器中和服务器交换信息也基本上式基于json的。

在现在的开发中,特别是在前后端分离的开发中,后端提供接口,前端通过接口拿取数据;

那么有一个问题来了,那就是该如何描述接口,可能有人说好办,通过接口文档,那么,文档如何维护呢,完全手写么?在这个自动化的时代,这样也太耗神费力了吧!当然不排除很多人是这么干的。

另外,如何体现字段规则,如字段长度,字段是否必填等验证规则,以及返回的字段有些什么东西,我想在文档里面不好体现这些吧。即使在文档中体现了,万一有些改动呢,有些事就不好办了。

关于如何描述json数据,我想没有什么能比json schema更合适了的吧;已成一个规范专门维护,还有一系列的配套工具,前端的后端的都有,比较好的接口文档工具Swagger就是基于它的。那么啰嗦了那么多,让我们来看看如何粗略的描述下json数据吧。


描述

JSON Schema本身就是JSON格式,自己描述自己,它们俩之间的关系可以理解为类与对象的关系,也可以理解为集合与元素的关系,或JSON Schema描述JSON数据的模式,怎么样好理解就怎么理解


数字

{
  "type": "number"
}

这样就可以把值描述成数字了
需要加个标题,我们只要加上title属性就好了

{
  "type": "number",
  "title": "字段1"
}

一般数字有最大值和最小值,我们可以加上maximum和minimum

{
  "type": "number",
  "maximum": 10,
  "minimum": 1
}

需要一个默认值,加上default即可

值得注意的是title, description, default是通用的


null

{
  "type": null
}


字符串

{
  "type": "string"
}

当字符串需要符合某种格式的时候,加上format

{
  "type": "string",
  "format": "url"
}

或者使用pattern,里面是正则表达式

{
  "type": "string",
  "pattern": "\\d+"
}

长度通过maxLength和minLength来描述


布尔值

{
  "type": "boolean"
}


对象

对象描述算是比较复杂的,不过也比较明了,通过properties来描述每个字段,每个字段的描述也是一个JSON Schema,也就是可以不断的嵌套

下面描述一个对象,拥有属性aa和bb,分别是数字和字符串

{
  "type": "object",
  "properties": {
    "aa": {
      "type": "number"
    },
    "bb": {
      "type": "string"
    }
  }
}

当某些字段必填的时候,加上required,是一个数组,里面是必填的字段

{
  "type": "object",
  "properties": {
    "aa": {
      "type": "number"
    },
    "bb": {
      "type": "string"
    }
  },
  "required": ["aa"]
}

除上面给出的以外,还能定义属性的个数;以及属性是动态的时候,可以定义属性满足的规则;另外还能定义依赖,也就是当某个字段提供的时候,相应的字段也必须提供


数组

{
  "type": "array"
}

maxItems,minItems为数字,定义数组有多长
uniqueItems为布尔值,定义是否有重复值
定义数组每一项满足的格式,加上items; 可以为对象,为一个JSON Schema或是一个对象数组,每个位置都为一个JSON Schema,描述对应位置的数据格式

以上只是JSON Schema的简略描述,冰上一角,更多的东西可以在官网找到,它的强大超乎你的想象,后续我还会介绍相应的工具,包括不仅限于

  • 根据代码自动生成文档
  • 校验
  • 表单生成
  • 通过代码生成JSON Schema
  • 自动化测试

另外欢迎光临个人小站,http://yuanxiaowa.github.io/,一些小工具望大家喜欢。 

 

本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://fly63.com/article/detial/2327

相关推荐

sublime 格式化Json

最近做数据匹配任务,需要生成很多json文件,但是每个json文件又太大,想要逐字段(key)检查,实在是太费眼,而且容易看错。因此每次生成的json文件,用sublime或者vscode将json数据格式化

为什么json 不能使用 int64类型

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。 它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999的一个子集

js之map及转换json、Object

set map<=>object map转obj,因为map打印出来其实是数组里套长度为二的数组,和java的不同 Object.create(null)、Object.create({}),{}的不同创建对象的区别 第一个,默认是null对象,啥方法都没有、后两个一样继承了object类,有两个内置方法

解决IE8以下低版本实现JSON.parse()与JSON.stringify()的兼容

将字符串和json对象的相互转换,我们通常使用JSON.parse()与JSON.stringify()。解决IE8以下低版本实现JSON.parse()与JSON.stringify()的兼容呢:利用eval方式解析、new Function形式、自定义兼容json的方法、head头添加mate等

js实现json数据格式化及压缩

经常写代码就免不了与json这种轻量级的数据打交道,一般我们得到的json字符串是混乱的,计算机不在乎,再乱它都能认识,作为人类,虽然也能认识,但识读起来比较困难。

js实现json格式化,以及json校验工具的简单实现

这篇文章主要讲解:json结构及形式、json字符串转化为json对象【通过eval( ) 方法,new Function形式,使用全局的JSON对象】、json校验格式化工具简单实现

百度JSON LD结构化数据代码分享

百度JSON LD结构化数据代码分享,搞外贸网站,企业网站这么就,对谷歌的 schema 结构化数据比较熟悉,但是对百度的结构化数据就了解太少了

解析Json字符串的三种方法

在很多时候,我们的需要将类似 json 格式的字符串数据转为json,下面将介绍日常中使用的三种解析json字符串的方法

解决IE8下JSON.stringify()自动将中文转译成unicode的方法

在IE8下JSON.stringify()自动将中文转译为unicode编码,原本选择的中文字符,传到后台变为了unicode编码,即u****的形式。查找资料后发现,与标准的JSON.stringify()不同,IE8内置的JSON.stringify()会自动将编码从utf-8转为unicode编码,导致出现这种类似于乱码的情况。

JSON.parse 三种实现方式

近日在翻红宝书,看到 JSON 那一章节,忽然想到:“如何用 JS 实现 JSON.parse?”带着这个疑问,我找到了 JSON 之父 Douglas Crockford 写的 ployfill,里面提供了三种实现方式,下面我们逐一来分析。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!