2020最后一天了,今天带大家一起来温故JSON语法规则的应用知识。
JSON
对象包含两个方法: 用于解析JSON的 parse()
方法,以及将对象/值转换为JSON字符串的 stringify()
方法。除了这两个方法, JSON这个对象本身并没有其他作用,也不能被调用或者作为构造函数调用。
描述
JSON 是一种语法,用来序列化对象、数组、数值、字符串、布尔值和 null
。它基于 JavaScript 语法,但与之不同:JavaScript不是JSON,JSON也不是JavaScript。
JSON有6种类型的值:对象、数组、字符串、数字、布尔值、null
JSON对象是一个容纳"名/值"对的无序集合。
名字:任意字符串
值:任意类型的JSON值,包括数组和对象(对象中可以嵌入对象)
注:JSON字符串必须使用双引号(单引号会报错)。
| JavaScript类型 | JSON 的不同点 |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 对象和数组 | 属性名称必须是双引号括起来的字符串;最后一个属性后不能有逗号。 |
| 数值 | 禁止出现前导零( JSON.stringify 方法自动忽略前导零,而在 JSON.parse 方法中将会抛出 SyntaxError);如果有小数点, 则后面至少跟着一位数字。 |
| 字符串 | 只有有限的一些字符可能会被转义;禁止某些控制字符; Unicode 行分隔符 (U+2028)和段分隔符 (U+2029)被允许 ; 字符串必须用双引号括起来。请参考下面的示例,可以看到 JSON.parse()
能够正常解析,但将其当作JavaScript解析时会抛出 SyntaxError
错误: let code = '"\u2028\u2029"';JSON.parse(code); // 正常eval(code); // 错误
|
[JavaScript 与 JSON 的区别]
完整的JSON语法定义如下:
JSON = null
or true or false
or JSONNumber
or JSONString
or JSONObject
or JSONArray
JSONNumber = - PositiveNumber
or PositiveNumber
PositiveNumber = DecimalNumber
or DecimalNumber . Digits
or DecimalNumber . Digits ExponentPart
or DecimalNumber ExponentPart
DecimalNumber = 0
or OneToNine Digits
ExponentPart = e Exponent
or E Exponent
Exponent = Digits
or + Digits
or - Digits
Digits = Digit
or Digits Digit
Digit = 0 through 9
OneToNine = 1 through 9
JSONString = ""
or " StringCharacters "
StringCharacters = StringCharacter
or StringCharacters StringCharacter
StringCharacter = any character
except " or \ or U+0000 through U+001F
or EscapeSequence
EscapeSequence = \" or \/ or \\ or \b or \f or \n or \r or \t
or \u HexDigit HexDigit HexDigit HexDigit
HexDigit = 0 through 9
or A through F
or a through f
JSONObject = { }
or { Members }
Members = JSONString : JSON
or Members , JSONString : JSON
JSONArray = [ ]
or [ ArrayElements ]
ArrayElements = JSON
or ArrayElements , JSON
一、对象
javascript中创建字面量:
var object = {
name:"lily",
age:22
};
或者:
var object = {
"name":"lily",
"age":22
};
JSON:
{
"name":"lily",
"age":22
}
二、数组
JSON数组采用的是javascript中数组字面量形式
扩展:
把数组和对象结合起来可以构成更复杂的数据结合
例如:
[
{
"name":"lily",
"age":22,
"job":"docter"
},
{
"name":"nicy",
"age":21,
"job":"teacher"
},
{
"name":"lily",
"age":22,
"job":"AE"
}
]
三、解析与序列化
JSON拥有和javascript类似的语法,可以把JSON数据结构解析为有用的javascript对象
1.JSON对象
收发JSON数据
读取、写入、发送和接收JSON数据对象时,需要转换成字符串,并能从字符串转换为JSON数据对象。(用于javascript相同的方式读写他们)
JSON对象有两个方法:
① stringify(): 把javascript对象序列化为JSON字符串
② parse(): 把JSON字符串解析为原生的javascript值
实例:
var book = {
title:"professional JavaScript",
authors:[
"lily"
],
edition:3,
year:2011
};
var jsonText = JSON.stringify(book);
alert(jsonText); //{"title":"professional JavaScript","authors":["lily"],"edition":3,"year":2011}
alert(typeof jsonText); //string
var bookCopy = JSON.parse(jsonText);
alert(typeof bookCopy); //object
这个例子中使用JSON.stringify()把一个javascript对象book序列化为一个JSON字符串,然后保存到jsonText中;将JSON字符串jsonText直接传给JSON.parse()就得到了相应的javascript值
注:序列化javascript对象时,最终值都是有效JSON数据类型的实例属性,任何无效的值都会被跳过
2.序列化选项
JSON.stringify()在序列化javascript对象时,可以接收两个参数
参数一:过滤器,可以是一个数组或函数
参数二:一个选项,表示是否在JSON字符串中保留缩进
1)过滤结果
如果过滤器的参数是数组,那么JSON.stringify()的结果中只包含数组中列出的属性
例如:
var book = {
"title":"professional JavaScript",
"authors":[
"lily"
],
edition:3,
year:2011
};
var jsonText = JSON.stringify(book,["title","edition"]);
alert(jsonText); //{"title":"professional JavaScript","edition":3}
alert(typeof jsonText); // string
2)字符串缩进:
JSON.stringify()方法的第三个参数用于控制结果中的缩进和空白符
3)toJSON()方法
给对象定义toJSON()方法,可以返回其自身的JSON数据格式
四、JSON访问值
第一种:简单数组
['item1','item2','item3']
取值:通过数字索引访问嵌入的值(第一项的索引为0)
['item1','item2','item3']
var items = ['item1','item2','item3'];
alert(items[0]); // item1
第二种:使用{}表示对象和符合数组
{ "key":"value" }
取值:通过键名访问嵌入的值
var oExample = { "name":"lily" };
alert(oExample.name); // lily
alert(oExample["name"]); // lily
使用这两种方式,可以用子记录(带命名的或数值的索引键)描述很多数据结构:
例如:
var oNovelist = {
"firstName":"lily",
"lastName":"russ",
"novels":
[
{
"title":"and choas died",
"year":"1970"
},
{
"title":"the famale man",
"year":"1976"
}
]
};
var msg = oNovelist.firstName+" "+oNovelist.lastName+"'s"+" "+oNovelist.novels[0].title+" "+"was published in"+oNovelist.novels[0].year;
alert(msg); // lily russ's and choas died was published in1970