JS操作json总结

                   JS操作json总结    

JSON是一种轻量级的数据交换格式,采用完全独立于语言的文本格式。同时,JSON是 JavaScript 原生格式,这意味着在 JavaScript 中处理 JSON数据不须要任何特殊的 API 或工具包。  为了方便地处理JSON数据,JSON提供了json.js包,下载地址:http://www.json.org/json.js;由于一些key值较多的json看起来非常头疼,可以借助json在线工具辅助解决json的易读性。(http://www.bejson.com)

一、在JSON中,有两种结构:对象和数组。

    1. 对象

      var json={"name":"张三",

                        "sex":"man",

                      "birthday":"1996-05-16"};

    2. 数组

    var jsonList=[{"name":"张三","sex":"man","birthday":"1996-05-16"},   

                          {"name":"李四","sex":"man","birthday":"1992-05-16"}];

  

  二、JSON字符串转换为JSON对象

   在数据传输流程中,json是以文本,即字符串的形式传递的, 而JS操作的是JSON对象,所以,JSON对象和JSON字符串之间的相互转换是关键。

    JSON字符串:

    var jsonString= '{"name":"张三","sex":"man","birthday":"1996-05-16"}';

    JSON对象:

    var jsonObj = {"name":"张三","sex":"man","birthday":"1996-05-16"};

    JSON字符串转换为JSON对象

     方法1: var obj = eval('(' + str + ')');

     方法2: var obj = str.parseJSON(); 

     方法3: var obj = JSON.parse(str); 

    取得json对象后就可以这样读取:

    Alert(obj.name);

    Alert(obj.sex);

    特别注意:如果obj本来就是一个JSON对象,那么运用 eval()函数转换后(哪怕是多次转换)还是JSON对象

                  但是运用 parseJSON()函数处理后会有问题(抛出语法异常)

   JSON对象转化为JSON字符串

    方法1:var last=obj.toJSONString(); 

    方法2:var last=JSON.stringify(obj); 

    alert(last);

   特别注意:除了eval()函数是js自带的之外,其他的多个要领都来自json.js包。新版本的 JSON 修改了 API,将 JSON.stringify() 和 JSON.parse() 两个要领都注入到了 Javascript 的内建对象里面,前者变成了 Object.toJSONString(),而后者变成 了 String.parseJSON()。如果提示找不到toJSONString()和parseJSON()要领,则说明您的json包版本太低。

你可能感兴趣的:(html/css)