本文是 重温基础 系列文章的第十六篇。 今日感觉:静。前端
系列目录:git
本章节复习的是JS中的关于JSON对象相关知识。github
前置知识:
JSON
是一种按照JavaScript
对象语法的数据格式。编程
概念有三点:json
JSON
全称JavaScript
对象表示法(JavaScript Object Notation)。
JSON
是存储和交换文本信息的语法。相似XML
。
JSON
比XML
更小、更快,更易解析。
———— 摘自 W3school JSON教程数组
JSON
使用 JavaScript
语法来描述数据对象,可是 JSON
仍然独立于语言和平台。JSON
解析器和 JSON
库支持许多不一样的编程语言。微信
JSON
在使用过程当中可做为一个对象或者字符串存在,看成为对象时,用于获取JSON
中的数据,而做为字符串时经常使用于网络数据传输。网络
JSON
语法规则:编程语言
一般,JSON
数据书写格式是名称/键值
:函数
"name" : "pingan"
复制代码
而JSON
的值能够是 :
true
或 false
)null
JSON经常有三种类型:
三种类型:简单值,对象和数组。
必须注意:JSON字符串必须是双引号,单引号会语法错误。
简单值能够是字符串:
"hello leo!"
复制代码
也能够是数字,逻辑值:
1
复制代码
内容放在花括号
内,是多个键值对。
JSON对象 与 js 对象的三个区别:
// js 对象
var obj = {
name : "pingan",
age : "25",
};
// json 对象
{
"name" : "pingan",
"age" : "25",
"box" : [
"a","b","c"
]
}
复制代码
内容放在方括号
内。
JSON数组也没有分号和变量,经常能够把JSON数组和对象结合使用,构成更复杂的数据集合。
[
{
"name" : "leo",
"age" : 25,
"box" : ["a","b","c"]
},
{
"name" : "pingan",
"age" : 25,
"box" : ["a","b","c"]
}
]
复制代码
JSON最多见的用法就是,从服务端获取JSON数据,再将JSON数据转成JavaScrip对象使用。
JSON对象有两个方法:
JSON.stringify()
: 序列化操做,将JavaScript对象
转换成JSON字符串
。JSON.prase()
:反序列化操做,将JSON字符串
解析成JavaScript值
。序列化操做经常使用JSON.stringify()
。
简单例子:
let leo = {
name : "leo",
age : 25,
box : ["a","b","c"]
}
let pingan = JSON.stringify(leo);
console.log(pingan); // "{"name":"leo","age":25,"box":["a","b","c"]}"
复制代码
注意:
JSON.stringify()
输出的JSON字符串不包含任何空格字符或缩进,所以结果就像上面那样。JavaScript对象
时,全部函数及原型成员都会被忽略,不体如今结果上。undefined
的任何属性都会被跳过。所以,最终的值都是有效的JSON数据类型的实例属性。
序列化操做经常使用JSON.parse()
。
简单例子:
let copyPingan = JSON.parse(pingan);
copyPingan; // {name: "leo", age: 25, box: Array(3)}
复制代码
若是传入JSON.parse()
的字符串不是有效的JSON,则会抛出错误。
注意:
虽然pingan
和copyPingan
属性相同,但二者独立,没有任何关系。
JSON.stringify()
除了要传入序列化对象做为参数,还能够接收其余两个参数,用来指定序列化JavaScript对象的方式:
JSON字符串
中保留缩进。单独或组合使用二者,能够更加全面深刻的控制JSON的序列化。
若过滤器的参数是数组,则JSON.stringify()
返回的结果将只包含数组中的属性:
var leo = {
name : "leo",
age : 25,
box : ["a","b","c"]
}
var pingan = JSON.stringify(leo,["name","age"]);
console.log(pingan); // "{"name":"leo","age":25}"
复制代码
若过滤器的参数是函数,则状况就不同了,传入的函数需有两个参数(属性名和属性值):
var leo = {
"name" : "leo",
"age" : 25,
"box" : ["a","b","c"]
}
var pingan = JSON.stringify(leo,function(key, value){
switch(key){
case "name":
return "我叫" + value
case "age":
return value + "岁"
default:
return value
}
});
console.log(pingan); // "{"name":"我叫leo","age":"25岁","box":["a","b","c"]}"
复制代码
注意:使用switch
的时候,必须指定default
不然会返回undefined
。
JSON.stringify()
第三个参数是个选项,控制结果中的缩进和空白符。
10
,超过10
则只会是10
。var leo = {
"name" : "leo",
"age" : 25,
"box" : ["a","b","c"]
}
var pingan = JSON.stringify(leo, null, 4);
console.log(pingan);
/* "{ "name": "leo", "age": 25, "box": [ "a", "b", "c" ] }" */
复制代码
JSON.parse()
能够接收一个函数做为参数,对每一个键值对调用,为了跟JSON.stringify()
的过滤函数
区别,这个函数成为还原函数
。
undefined
,则表示要从结果中删除对应的键。还原函数接收两个参数:属性名和属性值。
举例,在日期字符串转换为Date对象中,常常要用到还原函数:
var leo = {
"name" : "leo",
"age" : 25,
"date" : new Date(1993, 9, 9)
}
var pingan = JSON.stringify(leo);
var copy = JSON.parse(pingan,function (key, value){
// return key == "date" ? new Date(value) : value;
if(key == "date"){
return new Date(value);
}else{
return value;
}
})
console.log(copy);
// "{"name":"leo","age":25,"date":"1993-10-08T16:00:00.000Z"}"
复制代码
本部份内容到这结束
Author | 王平安 |
---|---|
pingan8787@qq.com | |
博 客 | www.pingan8787.com |
微 信 | pingan8787 |
每日文章推荐 | github.com/pingan8787/… |
JS小册 | js.pingan8787.com |
欢迎关注个人微信公众号【前端自习课】