【cJson】 JSON格式详解

前端之家收集整理的这篇文章主要介绍了【cJson】 JSON格式详解前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

转载地址:http://blog.csdn.net/dengjin20104042056/article/category/5754267

0.前言
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。 它基于JavaScript Programming Language,Standard ECMA-262 3rd Edition - December 1999的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C,C++,C#,Java,JavaScript,Perl,Python等)。 这些特性使JSON成为理想的数据交换语言。
JSON大致3种结构,JSON对象、JSON数组和JSON对象和数组嵌套。
1 JSON对象
JSON对象简单而言便是键值对或名值对,而“值”可以是数值、字符串和布尔类型等。
JSON对象具体格式如图1所示。

图1 JSON对象格式

1.1 JSON数值
请注意数值不需要加引号,键值对之间使用","。
【单个数值】
{“value”:12}
【多个数值】
{"maxValue":24,"minValue":12};
[javascript] view plain copy
  1. <script>
  2. varjsonObj={"maxValue":24,"minValue":12};
  3. console.log(jsonObj.maxValue);
  4. console.log(jsonObj.minValue);
  5. </script>
输出
24
12
1.2 JSON字符串
字符串需要加引号,键值对之间使用","。
【单个字符串】
{"name":"xukai871105"}
【多个字符串】
{"name":"xukai871105","blog":" http://blog.csdn.net/xukai871105 "}
[javascript] view plain copy
  1. <script>
  2. varjsonObj={"name":"xukai871105","blog":"http://blog.csdn.net/xukai871105"};
  3. console.log(jsonObj.name);
  4. console.log(jsonObj.blog);
  5. </script>
输出
[plain]
    xukai871105
  1. http://blog.csdn.net/xukai871105
1.3 JSON布尔
请注意JSON格式中的值可以使用布尔类型,且不需要加引号,如果true或false被引号包裹,那么便解析为JSON字符串,请处理稍有不同。
{"success":false}

varjsonObj={"success":false};
  • console.log(jsonObj.success);
  • </script>
  • 输出
    false

    2 JSON数组
    JSON数组的表达方法和C语言数组的表达方法完全相同。下面的例子中存在一个JSON对象,该JSON对象只有一个键值对,键为lists而键值为JSON数组——[5,6,7,8]。这里已经存在JSON类型的嵌套,具体请看下面一个例子。
    {"lists":[5,8]}

    图2 JSON数组格式
    varjsonObj={"lists":[5,8]};
  • console.log(jsonObj.lists);
  • for(vari=0;i<jsonObj.lists.length;i++){
  • console.log(jsonObj.lists[i]);
  • }
  • </script>
  • 输出
    [plain]
      [5,8]
    1. 5
    2. 6
    3. 7
    4. 8

    3 JSON嵌套
    JSON格式可以嵌套,所谓嵌套便是JSON对象中可包括JSON数组,JSON数组中可包括JSON对象。下面的例子中rows为JSON对象,对象中嵌套JSON数组,每一个JSON数组的元素又是一个JSON对象。这种嵌套情况在实际情况中经常出现。
    varjsonObj=
  • {
  • "total":3,
  • "rows":[
  • {
  • "title":"树莓派学习笔记——索引博文",
  • "url":"http://blog.csdn.net/xukai871105/article/details/23115627"
  • },
  • "title":"树莓派学习笔记——GPIO功能学习",248);">"url":"http://blog.csdn.net/xukai871105/article/details/12684617"
  • "title":"物联网学习笔记——索引博文",248);">"url":"http://blog.csdn.net/xukai871105/article/details/23366187"
  • }
  • ]
  • };
  • console.log(jsonObj.total);
  • vari=0;i<jsonObj.rows.length;i++){
  • console.log(jsonObj.rows[i].title);
  • console.log(jsonObj.rows[i].url);
  • </script>
  • 输出
    3
  • 树莓派学习笔记——索引博文
  • http://blog.csdn.net/xukai871105/article/details/23115627
  • 树莓派学习笔记——GPIO功能学习
  • http://blog.csdn.net/xukai871105/article/details/12684617
  • 物联网学习笔记——索引博文
  • http://blog.csdn.net/xukai871105/article/details/23366187

  • 4.javascript中eval函数
    【为什么要加括号 】
    加上圆括号的目的是迫使eval函数在评估JavaScript代码的时候强制将括号内的表达式(expression)转化为对象,而不是作为语句(statement)来执行。例如对象字面量{},如若不加外层的括号,那么eval会将大括号识别为JavaScript代码块的开始和结束标记,那么{}将会被认为是执行了一句空语句。参考——【3】 javascript eval和JSON之间的联系
    varjsonStr='{"total":3}';
  • varjsonObj=eval('('+jsonStr+')');
  • console.log(jsonObj.total);
  • </script>
  • 输出
    3

    5.常见错误
    【1】多一个逗号
    }或]前多一个,这种情况不符合JSON,但是某些浏览器可以容忍,例如chrome和火狐,但是某些浏览器就无法容忍,例如IE。最好还是选择JSON校验工具测试一下JSON数据包是否合法。请注意下面一个例子中url最后的",",该逗号是多余的。
    "title":"树莓派学习笔记——索引博文",
  • "url":"http://blog.csdn.net/xukai871105/article/details/23115627",248);">}

  • 6.参考资料
    【1】 JSON格式化工具
    【2】 JSON校验工具
    【3】 javascript eval和JSON之间的联系

    猜你在找的Json相关文章