JSON

JSON

   百度百科:JSON(JavaScript Object Notion,JS对象简谱)是一种轻量级数据交换格式。它基于ECMAScript(欧洲计算机协会指定的js规范)的一个子集,采用完全独立于编程语言的文本格来存储和表示数据。简洁和清晰的层次结构使得JSON称为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率

JSON的语法规则:

JSON是一个标记符的序列。这套标记符包含六个构造字符、字符串、数字和三个字面名

JSON是一个序列化的对象或数组

JSON的值:

值可以是对象、数组、数字、字符串或者三个字面值(false、null、true)中的一个。

值中的字面值中的英文必须使用小写

对象由花括号括起来的逗号分割的成员构成,成员是字符串键和上下文所述的值由逗号分割的键值对组成,

eg:
 {"name": "John Doe", "age": 18, "address": {"country" : "china", "zip-code": "10000"}}

数组是由方括号括起来的一组值构成

eg:[3, 1, 4, 1, 5, 9, 2, 6]

字符串与C或者JAVA的字符串非常相似。字符串是由双引号包围的任意数量Unicode字符的集合,使用反斜杠转义。一个字符(character)即一个单独的字符串(character string)。

数字也与C或者JAVA的数值非常相似。除去未曾使用的八进制与十六进制格式。除去一些编码细节。

eg:
{"a": 1, "b": [1, 2, 3]}
[1, 2, "3", {"a": 4}]
3.14
"plain_text"

JSON与JS对象的关系:

JSON可以理解为JS的字符串表示法,它使用文本表示一个JS对象的信息,本质是一个字符串。

eg:
var obj = {a: 'Hello', b: 'World'}; //这是一个对象,注意键名也是可以使用引号包裹的
var json = '{"a": "Hello", "b": "World"}'; //这是一个 JSON 字符串,本质是一个字符串

JSON与JS对象互转:

JSON→JS对象    [使用JSON。parse()方法]

JS对象→JSON    [使用JSON.stringify()方法]

var obj = JSON.parse('{"a": "Hello", "b": "World"}'); //结果是 {a: 'Hello', b: 'World'}

var json = JSON.stringify({a: 'Hello', b: 'World'}); //结果是 '{"a": "Hello", "b": "World"}'

常用类型:

任何支持的类型都可以通过JSON来表示,例如字符串、数字、对象、数组等。但是对象和数组是比较特殊且常用的两种类型。

对象:对象在JS中是使用花括号包裹{}起来的内容吗,数据结构为{key1:value1,key2:value2,...}的键值对结构。在面向对象的语言中,key为对象的属性,value为对应的值。键名可以使用整数和字符串来表示。值的类型可以是任意类型

数组:数组在JS中是方括号[]包裹起来的内容,数据结构为["java","javascript","vb",...]的索引结构。在JS中,数组是一种比较特殊的数据类型,它也可以像对象那样使用键值对,但还是索引使用的多。值的类型可以是任意类型

JSON和XML的比较:

可读性:JSON和XML的可读性不相上下,一边是简易的语法,一边是规范的标签形式,很难分出胜负

可扩展性:XML天生有很好的扩展性,JSON当然也有,没有什么是XML可以扩展而JSON不可以扩展的。不过JSON在JavaScript主场作战,可以存储JavaScript复合对象,有着XML不可比拟的优势。

编码难度:XML和HTML都有特工的工具编码,在无工具的情况下,XML文档要多很多结构上的字符。

实例比较:

用XML表示中国部分省市数据如下:

<?xml version="1.0" encoding="utf-8"?>
<country>
    <name>中国</name>
    <province>
        <name>黑龙江</name>
        <cities>
            <city>哈尔滨</city>
            <city>大庆</city>
        </cities>
    </province>
    <province>
        <name>广东</name>
        <cities>
            <city>广州</city>
            <city>深圳</city>
            <city>珠海</city>
        </cities>
    </province>
    <province>
        <name>台湾</name>
        <cities>
            <city>台北</city>
            <city>高雄</city>
        </cities>
    </province>
    <province>
        <name>新疆</name>
        <cities>
            <city>乌鲁木齐</city>
        </cities>
    </province>
</country>

用JSON表示如下:

{
    "name": "中国",
    "province": [{
        "name": "黑龙江",
        "cities": {
            "city": ["哈尔滨", "大庆"]
        }
    }, {
        "name": "广东",
        "cities": {
            "city": ["广州", "深圳", "珠海"]
        }
    }, {
        "name": "台湾",
        "cities": {
            "city": ["台北", "高雄"]
        }
    }, {
        "name": "新疆",
        "cities": {
            "city": ["乌鲁木齐"]
        }
    }]
}

可以看到,JSON 简单的语法格式和清晰的层次结构明显要比 XML 容易阅读,并且在数据交换方面,由于 JSON 所使用的字符要比 XML 少得多,可以大大得节约传输数据所占用的带宽。

 

posted @ 2022-05-28 16:19  ~晶晶~  阅读(10)  评论(0编辑  收藏  举报