JSON——JavaScript程序设计笔记(15)
2015-08-20 02:03
435 查看
第20 章 JSON
JSON可以用来表示简单值JSON用来表示对象
{
“name”: “Nicholas”,
“age”: 29
}
对象的属性必须加双引号,这在JSON 中是必需的。属性的值可以是简单值,也可以是复杂类型值,因
此可以像下面这样在对象中嵌入对象:
{
“name”: “Nicholas”,
“age”: 29,
“school”: {
“name”: “Merrimack College”,
“location”: “North Andover, MA”
}
}
JSON用来表示数组
[25, “hi”, true]
JSON 数组也没有变量和分号。把数组和对象结合起来,可以构成更复杂的数据集合
解析与序列化
JSON 对象有两个方法:stringify()和parse()。在最简单的情况下,这两个方法分别用于把JavaScript 对象序列化为JSON 字符串和把JSON 字符串解析为原生JavaScript 值。
JSON.stringify()除了要序列化的JavaScript 对象外,还可以接收另外两个参数,这两个参数用于指定以不同的方式序列化JavaScript 对象。第一个参数是个过滤器,可以是一个数组,也可以是一个函数;第二个参数是一个选项,表示是否在JSON 字符串中保留缩进。
如果过滤器参数是数组,那么JSON.stringify()的结果中将只包含数组中列出的属性
过滤器参数还可以是函数
var book = { "title": "Professional JavaScript", "authors": [ "Nicholas C. Zakas" ], edition: 3, year: 2011 }; var jsonText = JSON.stringify(book, function(key, value){ switch(key){ case "authors": return value.join(",") case "year": return 5000; case "edition": return undefined; default: return value; } });
函数过滤器根据传入的键来决定结果。如果键为”authors”,就将数组连接为一个字符串;
如果键为”year”,则将其值设置为5000;如果键为”edition”,通过返回undefined 删除该属性。
最后,一定要提供default 项,此时返回传入的值,以便其他值都能正常出现在结果中
缩进参数可以是数值
也可以是一个字符串,则这个字符串将在JSON 字符串中被用作缩进字符
有时候,JSON.stringify()还是不能满足对某些对象进行自定义序列化的需求。在这些情况下,
可以给对象定义toJSON()方法,返回其自身的JSON 数据格式
假设把一个对象传
入JSON.stringify(),序列化该对象的顺序如下。
(1) 如果存在toJSON()方法而且能通过它取得有效的值,则调用该方法。否则,返回对象本身。
(2) 如果提供了第二个参数,应用这个函数过滤器。传入函数过滤器的值是第(1)步返回的值。
(3) 对第(2)步返回的每个值进行相应的序列化。
(4) 如果提供了第三个参数,执行相应的格式化。
相关文章推荐
- js模拟的静态私有变量
- JavaScript学习笔记——事件
- js正则匹配只能输入有效数字可加小数点
- javascript深入理解js闭包
- 错误处理与调试——JavaScript高级程序设计笔记(14)
- javascript如何操作HTML下拉列表标签
- js实现Select列表内容自动滚动效果代码
- JS给Textarea文本框添加行号的方法
- js图片翻书效果代码分享
- js代码实现无缝滚动(文字和图片)
- JS实现支持多选的遍历下拉列表代码
- JS实现的Select三级下拉菜单代码
- js实现文字在按钮上滚动的方法
- js实现按钮颜色渐变动画效果
- JS实现的通用表单验证插件完整实例
- js限制文本框的输入内容代码分享(3类)
- js变形金刚文字特效代码分享
- canvas导出为图片并用JS下载
- js 中{},[]中括号,大括号使用详解
- JS中&&和||用法