一. json可以表示3种类型的值:

  简单值 、 对象、 数组 
 
表示对象时:》1. 没有变量的概念 ,所以不用申明变量
                   》2. 没有末尾结束时的分号 ;
                   》3. 对象属性并需要加 双引号 
                   》4. 同一对象中绝不能出现两个同名属性
 
二.json 的两个方法:
 
    JSON.stringify (object); , JSON.parse (object);
    在简单情况下,以上两个方法,用于把javascript对象序列化, 和把JSON字符串解析为原生javascript的值
    eg:执行如下代码,会在浏览器显示 {"title":"A book title","authors":["ren jing"],"edition":3,"year":2011} 此结果
     var book = {
"title" : "A book title",
"authors" : [
"ren jing"
],
edition : 3,
year : 2011
};
var jsonText = JSON.stringify(book);
document.write(jsonText);

1. 对于详细序列化 javascript 使用 JSON.stringify (object )时 ,还可再传入两个参数;

》  第一个参数 为过滤器 ,可以为数组:

var jsonText = JSON.stringify(book,["title","edition"]);

也可以为函数,当传入的为函数时,传入的函数接收两个参数,属性名和属性值:

     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;
}
});
alert(jsonText);

运行结果为:{"title":"A book title","authors":"ren jing","year":5000}

》第二个参数是一个选项,表示是否在JSON字符串中保留缩进,用于控制结果中的缩进和空白符。

若这个参数是一个数值,那它表示每个级别缩进的空格数(最大缩进空格数为10,所有大于10的数会自动转换为10):

var jsonText = JSON.stringify(book,null,10);

若缩进参数是一个字符串而非数值,则这个字符串将在JSON字符串中被用作缩进字符(不再使用空格,最大限制依然为10):

var jsonText = JSON.stringify(book,null,"- -"); 

有时候我们可以定义一个toJSON()方法,返回其自身的JSON数据格式,更好的进行自定义序列化的需求。

  对于序列化对象的顺序,我们应该注意的是:

(1)如果存在toJSON()方法且能通过它取得有效的值,则调用该方法。否则,返回对象本身。

(2)如果提供了第二个参数,应用这个函数过滤器。传入函数过滤器的值是第(1)步返回的值。

(3)对于第(2)步返回的每个值进行相应的序列化。

(4)如果提供了第三个参数,执行相应的格式化。

2.对于解析json数据,也可以接受另一个参数,该参数是一个函数:

     var book = {
"title" : "A book title",
"authors" : [
"ren jing"
],
edition : 3,
year : 2011,
releaseDate : new Date(2015,07,1)
};
var jsonText = JSON.stringify(book);
var bookCopy = JSON.parse(jsonText,function(key,value){
if(key =="releaseDate"){
return new Date(value);
}else{
return value;
}
})
alert(bookCopy.releaseDate.getFullYear());

通过添加releaseDate属性,通过序列化将数据序列化为有效的JSON字符串后 ,再进行解析,运行结果为:2015

(将此内容作为自己的个人笔记,参考来源于javascript高级程序设计 第三版)

json相关的一些用法的更多相关文章

  1. json简介及JsonCpp用法

    [时间:2017-04] [状态:Open] [关键词:数据交换格式,json,jsoncpp,c++,json解析,OpenSource] json简介 本文仅仅是添加我个人对json格式的理解,更 ...

  2. 关于 pgsql 数据库json几个函数用法的效率测试

    关于 pgsql 数据库json几个函数用法的效率测试 关于pgsql 几个操作符的效率测试比较1. json::->> 和 ->> 测试方法:单次运行100次,运行10个单次 ...

  3. boost json生成和解析用法

    json c++库还是有很多的,因为工作上经常使用boost,这里选用boost的json,记录下用法. 举个栗子: 如果我们要生成如下格式的json: { "name":&quo ...

  4. json相关知识

    整理json相关知识: 1.for in 循环获取json中的键(key)与值(value) <!DOCTYPE html> <html lang="en"> ...

  5. SQL server 存储过程 C#调用Windows CMD命令并返回输出结果 Mysql删除重复数据保留最小的id C# 取字符串中间文本 取字符串左边 取字符串右边 C# JSON格式数据高级用法

    create proc insertLog@Title nvarchar(50),@Contents nvarchar(max),@UserId int,@CreateTime datetimeasi ...

  6. jquery下json数组的操作用法实例

    jquery下json数组的操作用法实例: jquery中操作JSON数组的情况中遍历方法用的比较多,但用添加移除这些好像就不是太多了. 试过json[i].remove(),json.remove( ...

  7. plpgsql 数组、JSON相关

    Function Return Type Description Example Result array_append(anyarray,anyelement) anyarray append an ...

  8. react第十七单元(redux和组件之间的通信,react-redux的相关api的用法)

    第十七单元(redux和组件之间的通信,react-redux的相关api的用法) #课程目标 什么是redux-redux react-redux的作用是什么 react-redux如何应用 #知识 ...

  9. Cocos2d-x数据相关的类用法简介(附示例)

    (搬运自我在SegmentFault的博客) 在Cocos2d-x的学习和使用中,我遇到了很多关于数据的操作.在这个过程中,我学习了Cocos2d-x自带的很多功能.下面我把接触到的类罗列在下面,给出 ...

随机推荐

  1. Python: Windows 7 64位 安装、使用 pymongo 3.2

    官网tutorial:  http://api.mongodb.com/python/current/tutorial.html 本教程将要告诉你如何使用pymongo模块来操作MongoDB数据库. ...

  2. The certificate used to sign ***has either expired or has been revoked. An updated certificate is required to sign and install the application

    真机测试的时候弹出这样的提示:The certificate used to sign ***has either expired or has been revoked. An updated ce ...

  3. 用flex做垂直居中

    <div class="flex-cont flex-centerbox"> <div class="center-cont"> < ...

  4. gulp如何使用

    简介: gulp是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器:她不仅能对网站资源进行优化,而且在开发过程中很多重复的任务能够使用正确的工具自动完成:使用她,我们不仅可以很愉快的编写代码 ...

  5. 安装minicom

    安装配置过程: 1.sudo apt-get install minicom 2.执行:sudo minicom -s 配置minicom 切记加sudo 3.然后选择Serial port setu ...

  6. 前端弹出层框架layer

    http://www.layui.com/doc/modules/layer.html#layer.confirm

  7. Chrome 中的彩蛋,一款小游戏,你知道吗?

    今天看到一篇文章,介绍chrome中的彩蛋,带着好奇心进去看了一眼,没想到发现了一款小游戏,个人觉得还不错,偶尔可以玩一下,放松放松心情!^_^ 当 Chrome 无法连接到互联网时, 或者上着网突然 ...

  8. NXP恩智浦P89V51RB2/RC2/RD2单片机解密芯片破解方法!

    NXP恩智浦P89V51RB2/RC2/RD2单片机解密芯片破解 P89V51RB2/RC2/RD2是一款80C51微控制器,包含16/32/64kB Flash和1024字节的数据RAM. P89V ...

  9. git本地有修改如何强制更新

    本地有修改和提交,如何强制用远程的库更新更新.我尝试过用git pull -f,总是提示 You have not concluded your merge. (MERGE_HEAD exists). ...

  10. java-并发-同步

    浏览以下内容前,请点击并阅读 声明 线程间的通信主要是通过访问以及对象引用字段,这种形式的通信非常高效,但是会产生两种可能的错误:线程干扰和内存一致性错误,反正这些错误的工具就是同步. 然而,同步可能 ...