js解析与序列化json数据(一)json.stringify()的基本用法
2018-10-12 13:50
736 查看
早期的JSON解析器基本上就是使用JavaScript的eval()函数。由于JSON是JavaScript语法的自己,因此eval()函数可以解析、解释并返回JavaScript的对象和数组。
ECMAScript 5对解析JSON的行为进行了规范,定义了全局对象JSON。
JSON对象有两个方法:stringify()和parse()。在最简单的情况下,这两个方法分别用于把JavaScript对象序列化为JSON字符串和把JSON字符串解析为原生JavaScript。例如:
新建一个HTML:代码如下:
默认情况下,JSON.stringify()输出的JSON字符串不包含任何空字符或缩进,因此保存在jsonBook中的字符串如下所示:
在序列化JavaScript对象时,所有函数及原型成员都会被有意忽略,不体现在结果中。此外,值为undefined的任何属性也都会被跳过。结果中最终都是值为有效JSON数据类型的实例属性。
注意,虽然book与objectBook具有相同的属性,但它们是两个独立的、没有任何关系的对象。如果传给JSON.parse()的字符串不是有效的JSON,该方法会抛出错误。
ECMAScript 5对解析JSON的行为进行了规范,定义了全局对象JSON。
JSON对象有两个方法:stringify()和parse()。在最简单的情况下,这两个方法分别用于把JavaScript对象序列化为JSON字符串和把JSON字符串解析为原生JavaScript。例如:
新建一个HTML:代码如下:
<html>
<head>
<title></title>
<script type="text/javascript">
function init()
{
var book={
title:"JavaScript高级程序设计",
authors:[
"Nicholas C. Zakas"
],
edition:3,
year:2011
};
var jsonBook=JSON.stringify(book);
var objectBook=JSON.parse(jsonBook);
var title=objectBook.title;} </script> </head> <body> <input type="button" onclick="init()" value="测试" /> </body> </html>
默认情况下,JSON.stringify()输出的JSON字符串不包含任何空字符或缩进,因此保存在jsonBook中的字符串如下所示:
{"title":"JavaScript高级程序设计","authors":["Nicholas C. Zakas"],"edition":3,"year":2011}
在序列化JavaScript对象时,所有函数及原型成员都会被有意忽略,不体现在结果中。此外,值为undefined的任何属性也都会被跳过。结果中最终都是值为有效JSON数据类型的实例属性。
注意,虽然book与objectBook具有相同的属性,但它们是两个独立的、没有任何关系的对象。如果传给JSON.parse()的字符串不是有效的JSON,该方法会抛出错误。
您可能感兴趣的文章:
相关文章推荐
- js解析与序列化json数据(一)json.stringify()的基本用法
- js解析与序列化json数据(一)json.stringify()的基本用法
- 用js解析经json序列化后的C#的DateTime类型数据
- QJson解析数据基本用法
- 用js解析经后台json序列化后的C#的DateTime类型数据
- js解析与序列化json数据(三)json的解析探讨
- js解析与序列化json数据(三)
- 用js解析经json序列化后的C#的DateTime类型数据
- js解析与序列化json数据(二)序列化探讨
- 用js解析经json序列化后的C#的DateTime类型数据
- js解析与序列化json数据(一)
- js解析与序列化json数据(二)
- js解析与序列化json数据(三)json的解析探讨
- xml json 数据封装 传递(序列化) 解析
- JS解析json数据(如何将json字符串转化为数组)
- 《项目经验》--后台一般处理程序向前台JS文件传递JSON,JS解析JSON,将数据显示在界面--显示在DropDownList 或 显示在动态创建的table中
- JS解析json数据(json字符串和数组之间相互转换)
- JS解析json数据并将json字符串转化为数组的实现方法
- js中请求URL获得json数据,将数据解析并建表插入