JavaScript高级编程———JSON

< script >
/*JSON的语法可以表达一下三种类型的值
简单值:使用与javas相同的语法,可以在JSON中表达字符串、数值、布尔值和null,但JSON不支持javascript中的特殊值undefined
对象:对象作为一种复杂数据类型,表示的是一组无序的键值对,而每个键值对中的值可以是简单值,也可以是复杂数据类型的值
数组: 数组也是一种复杂数据类型,表示一组有序的值的列表,可以通过数值索引来访问其中的值,数值的值也可以是任意类型——简单值、对象、数组
*/
//javascript中的对象字面量
var person = {
name: "Nicholas",
age:
};
//JSON的对象字面量,其次JSON的末尾是没有分号,对象属性必须加双引号,这是JSON中是必需的,属性的值可以是简单值,也可以是复杂类型值
var object = {
"name": "Nicholas",
"age": ,
"school": {
"name": "Merrimack College",
"location": "North Andover, MA"
}, };
/*数组:JSON中的第二种复杂数据类型是数组,JSON数组采用的就是JavaScript中的数组字面量形式*/
//javascript中的数组字面量
var values = [, "hi", true]; //JSON的数组也没有变量和分号,把数组和对象结合起来,可以构成更复杂的数据集合
[{
"title": "Professional JavaScript",
"authors": ["Nicholas C. Zakas"],
"edition": ,
"year":
},
{
"title": "Professional JavaScript",
"authors": ["Nicholas C. Zakas"],
"edition": ,
"year":
},
{
"title": "Professional Ajax",
"authors": ["Nicholas C. Zakas", "Jeremy McPeak", "Joe Fawcett"],
"edition": ,
"year":
},
{
"title": "Professional Ajax",
"authors": ["Nicholas C. Zakas", "Jeremy McPeak", "Joe Fawcett"],
"edition": ,
"year":
},
{
"title": "Professional JavaScript",
"authors": ["Nicholas C. Zakas"],
"edition": ,
"year":
}] /*早期JSON对象基本上市javascript的eval()函数
JSON对象有两个方法:stringify()、parse,在最简单的情况下,这两个方法分别用于
把javascript对象序列化为JSON字符串和把JSON字符串解析为原生javascript值
*/
var book = {
title: "Professional Javascript",
authors: ["Nicholas"],
edition: ,
year: ,
//toJSON: function () {
// return this.title;
//},
releaseDate: new Date(, , )
};
//使用JSON.stringify()将一个javascript对象序列化为一个JSON字符串,然后将它保存在jsonText中
var jsonText = JSON.stringify(book);
//将JSON字符串直接传递给JSON.parse()就可以得到相应的javascript值
var jsonParse = JSON.parse(jsonText);
console.log(jsonText);
console.log(jsonParse); /*序列化选项:实际上,JSON.stringify()除了序列化的javascript对象外,还可以接收另外两个参数,
这两个参数用于指定以不同的方式序列化javascript对象,第一个参数是过滤器,可以是一个数组,
也可以是一个函数,第二个参数是一个选项,表示是否在JSON字符串中保留缩进
*/ //过滤结果(这个属性与将要序列化的对象中的属性是对应的,因此在返回的结果字符串中,就只会包含这两个属性)
var jsonT = JSON.stringify(book, ["title", "edition"]);
console.log(jsonT);
//如果键为 "year" ,则将其值设置为 5000 ;如果键为 "edition" ,通过返回 undefined 删除该属性。
//最后,一定要提供 default 项,此时返回传入的值,以便其他值都能正常出现在结果中
var jsontarget = JSON.stringify(book,
function(key, value) {
switch (key) {
case "authors":
return value.join(",")
case "year":
return ;
case "edition":
return undefined;
default:
return value;
}
});
console.log(jsontarget); //字符串缩进:JSON.stringify()方法的第三个参数用于空值结果中的缩进和空白符,如果这个参数是一个值,那它表示的是每个级别缩进的空格数
var jsontrim = JSON.stringify(book, null, );
console.log(jsontrim); /*toJSON() 方法可以将 Date 对象转换为字符串,并格式化为 JSON 数据格式。JSON 数据用同样的格式就像x ISO-8601 标准: YYYY-MM-DDTHH:mm:ss.sssZ
如果存在 toJSON() 方法而且能通过它取得有效的值,则调用该方法。否则,返回对象本身
*/ /*解析选项 先是为 book 对象新增了一个 releaseDate 属性,该属性保存着一个 Date 对象。
这个对象在经过序列化之后变成了有效的 JSON 字符串,然后经过解析又在 bookCopy 中还原为一个 Date对象。
还原函数在遇到 "releaseDate" 键时,会基于相应的值创建一个新的 Date 对象。
结果就是bookCopy.releaseDate 属性中会保存一个 Date 对象。正因为如此,才能基于这个对象调用getFullYear() 方法。
*/
var bookCopy = JSON.parse(jsonText,
function(key, value) {
if (key == "releaseDate") {
return new Date(value);
} else {
return value;
}
});
alert(bookCopy.releaseDate.getFullYear());
< /script>/

  

JavaScript高级编程———JSON的更多相关文章

  1. javascript高级编程笔记01(基本概念)

    1.在html中使用JavaScript 1.  <script> 元素 <script>定义了下列6个属性: async:可选,异步下载外部脚本文件. charset:可选, ...

  2. JavaScript高级编程———基本包装类型String和单体内置对象Math

    JavaScript高级编程———基本包装类型和单体内置对象 <script> var stringObject = new String("hello world") ...

  3. JavaScript高级编程——Date类型

    JavaScript高级编程——Date类型 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml" ...

  4. JavaScript高级编程——Array数组迭代(every()、filter()、foreach()、map()、some(),归并(reduce() 和reduceRight() ))

    JavaScript高级编程——Array数组迭代(every().filter().foreach().map().some(),归并(reduce() 和reduceRight() )) < ...

  5. JavaScript高级编程——引用类型、Array数组使用、栈方法

    JavaScript高级编程——引用类型.Array数组使用.栈方法 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999 ...

  6. JavaScript高级编程———数据存储(cookie、WebStorage)

    JavaScript高级编程———数据存储(cookie.WebStorage) <script> /*Cookie 读写删 CookieUtil.get()方法根据cookie的名称获取 ...

  7. JavaScript高级编程(一)

    书中第2章,在HTML中使用JavaScript摘要总结 2.1 <script>元素 <script>中的5个属性:charset:可选.表示通过src属性指定的代码的字符集 ...

  8. JavaScript高级编程 (1) - javscript是什么

    <重温javascript>这是一系列 javascript 的学习笔记,部分内容摘自书本或者网络,我这里只是基于自己的理解进行了梳理整理. 一个完整的 javscript 实现是由以下3 ...

  9. JavaScript高级编程II

         原文地址: http://www.onlamp.com/pub/a/onlamp/2007/08/23/advanced-javascript-ii.html?page=1 在前面的文章中, ...

随机推荐

  1. 浅谈ES6原生Promise

    浅谈ES6原生Promise 转载 作者:samchowgo 链接:https://segmentfault.com/a/1190000006708151 ES6标准出炉之前,一个幽灵,回调的幽灵,游 ...

  2. shopify网站转化率优化之结账页checkout优化

    昨天分享了“利用GOOGLE地图API实现shopify结账页checkout地址自动填写地址字段”是个非常屌的功能,但shopify默认的结账页checkout是这样的如图 [caption id= ...

  3. [LeetCode] 反转整数

    题目: 给定一个 32 位有符号整数,将整数中的数字进行反转. 示例 1: 输入: 123 输出: 321 示例 2: 输入: -123 输出: -321 示例 3: 输入: 120 输出: 21 注 ...

  4. jdk1.8+SpringAOP注解报java.lang.IllegalArgumentException: error at ::0 can't find referenced pointcut select错误的不知原因的解决办法[仅供参考]

    先说办法:如果Aspectweaver-1.*.*jar这三个包版本比较低, 比如1.5.0这一层次的,可以找版本高一点的包替换低版本的包,问题可以得到解决 jar包的下载地址:https://mvn ...

  5. [原创]Base32加密解密工具

    工具: Base32_Decode编译: VS2012  C# (.NET Framework v2.0)组织: K8搞基大队[K8team]作者: K8拉登哥哥博客: http://qqhack8. ...

  6. 在MVC3中修改KindEditor实现上传图片到指定文件夹

    KindEditor编辑器默认上传的图片文件夹,是根据系统时间自动生成的,图片是自动上传到这些文件夹里面,无法选择.如果要上传图片到指定文件夹,像相册一样管理图片,则需要扩展KindEditor编辑器 ...

  7. Python多线程-Event(事件对象)

    Event 事件对象管理一个内部标志,通过set()方法将其设置为True,并使用clear()方法将其设置为False.wait()方法阻塞,直到标志为True.该标志初始为False. 方法: i ...

  8. redmine设置user projects时无法delete的处理方法

    对于user,当要在管理员界面处理其projects权限时,发现部分项目只有edit按钮,而部分项目还有一个delete按钮. “delete”,直接点击按钮即可删除对应project权限,表明该pr ...

  9. .NET Framework 源码查看与调试

    1. 直接下载.NET Framework源代码(下载地址),然后用Visual Studio 13 打开查看.2. 在线查看,网址:http://referencesource.microsoft. ...

  10. JavaScript创建对象的方法汇总

    JavaScript中的对象 ECMA-262把对象定义为:“无序属性的集合,其属性可以包含基本值.对象或者函数.”严格来讲,这就相当于说对象是一组没有特性顺序的值.对象的每一个属性或方法都有一个名字 ...