JavaScript 之 JSON 对象

一、JSON 是什么

  JSON (JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。 同时也易于机器解析和生成。 JSON 采用完全独立于语言的文本格式, 而且很多语言都提供了对 json 的支持(包括 C, C++, C#, Java, JavaScript, Perl, Python 等),这样就使得 JSON 成为理想的数据交换格式。

  Json 是一种轻量级的数据交换格式(轻量级指的是跟 xml 做比较)。

  数据交换指的是客户端和服务器之间业务数据的传递格式。

二、JSON 的定义

  json 是由键值对组成,并且由花括号(大括号)包围,每个键由引号引起来,键和值之间使用冒号进行分隔,多组键值对之间使用逗号进行分隔。

  注意:值可以是任何类型,如 Number,String,boolean值,Object,数组,甚至是 JSON 数组。

  语法格式:

var jsonObj = {
        "key1" : value1,
        "key2" : value2,
        "key3" : value3  
}

  

  Demo:

 1  var jsonObj = {
 2             "key1":12,
 3             "key2":"abc",
 4             "key3":true,
 5             "key4":[11,"arr",false],
 6             "key5":{
 7                 "key5_1" : 551,
 8                 "key5_2" : "key5_2_value"
 9             },
10             "key6":[{
11                 "key6_1_1":6611,
12                 "key6_1_2":"key6_1_2_value"},{
13                 "key6_2_1":6621,
14                 "key6_2_2":"key6_2_2_value"
15             }]
16         };

三、JSON 的访问

  json 本身就是一个对象,其中的 key 可以理解为是对象的一个属性,所以访问 key 就像访问对象的属性一样。

  语法:

json 对象.key

  Demo:

 1         alert(typeof(jsonObj));// object json 就是一个对象
 2         alert(jsonObj.key1); //12
 3         alert(jsonObj.key2); // abc
 4         alert(jsonObj.key3); // true
 5         alert(jsonObj.key4);// 得到数组[11,"arr",false]
 6         // json 中 数组值的遍历
 7         for(var i = 0; i < jsonObj.key4.length; i++) {
 8             alert(jsonObj.key4[i]);
 9         } 
10         alert(jsonObj.key5.key5_1);//551
11         alert(jsonObj.key5.key5_2);//key5_2_value
12         alert( jsonObj.key6 );// 得到 json 数组
13         // 取出来每一个元素都是 json 对象
14         var jsonItem = jsonObj.key6[0];
15         // alert( jsonItem.key6_1_1 ); //6611
16         alert( jsonItem.key6_1_2 ); //key6_1_2_value    

四、json 的两个常用方法

  Json 的存在有两种形式:

    (1)以对象的形式存在,称之为 Json 对象;

    (2)以字符串的形式存在,称之为 Json 字符串。

    通常在操作 Json 中的数据的时候,需要 Json 对象的格式,而在客户端与服务器之间进行数据交换的时候,使用 Json 字符串。

  转换方法:

JSON.stringify()      把 json 对象转换成 json 字符串
JSON.parse()          把 json 字符串转换成 json 对象

  Demo:

 1   var json = {
 2          "key1" : 123,
 3          "key2" : "abc"
 4        };
 5 
 6        // 把 json 对象转换成为 json 字符串
 7        var jsonObjString = JSON.stringify(jsonObj); // 特别像 Java 中对象的 toString
 8        alert(jsonObjString)
 9        // 把 json 字符串。 转换成为 json 对象
10        var jsonObj2 = JSON.parse(jsonObjString);
11        alert(jsonObj2.key1);// 12
12        alert(jsonObj2.key2);// abc

 

原文地址:https://www.cnblogs.com/niujifei/p/12488808.html