使用Jquery解析Json基础知识

转载 2015年07月10日 17:29:02

前言

在WEB数据传输过程中,json是以文本,即字符串的轻量级形式传递的,而客户端一般用JS操作的是接收到的JSON对象,所以,JSON对象和JSON字符串之间的相互转换、JSON数据的解析是关键。

先明确2个概念例如:

JSON字符串:

var str1 = '{ "name": "deyuyi", "sex": "man" }';

JSON对象:

var str2 = { "name": "deluyi", "sex": "man" };

 

可以简单这样理解:

JSON对象是直接可以使用JQuery操作的格式,如C#中可以用对象(类名)点出属性(方法)一样;

JSON字符串仅仅只是一个字符串,一个整体,不截取的话没办法取出其中存储的数据,不能直接使用,除非你只想alert()他;

 

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

 

要使用上面的str1,必须使用下面的方法先转化为JSON对象:

 

A:eval函数

eval函数可以直接将本质符合或者近似符合JSON格式的字符串转换为JSON对象,使用方式如:

eval('(' + str + ')'); //其中str就是满足本标题描述的字符串

复制代码
    //由JSON字符串转换为JSON对象
    var str='{ "name": "John" }';
    var obj = eval('(' + str + ')'); 
    alert( obj.name);

    var str2="{ 'name': 'John' }";
    var obj2 = eval('(' + str2 + ')'); 
    alert( obj2.name);

    var str3="{ name: 'John' }";
    var obj3 = eval('(' + str3 + ')'); 
    alert( obj3.name);
复制代码

以上均会输出结果“john”。

Eval方式可以转换以下标准和非标准格式字符串:

   var str="{ 'name': 'John' }";
   var str2='{ "name": "John" }';
   var str3="{ name: 'John' }";

参见本例下载包中:JqueryDemo1.html

 

B:parseJSON函数

另一种将标准字符串转换为JSON对象的函数是parseJSON(),使用方式如jQuery.parseJSON(str)//其中str就是满足本标题描述的字符串

    //由JSON字符串转换为JSON对象
    var str='{ "name": "John" }';
    var obj = jQuery.parseJSON(str)
    alert("1"+ obj.name);

以上均会输出结果“john”。

此种方式仅支持标准格式:var str='{ "name": "John" }';

参见本例下载包中:JqueryDemo2.html

 

C:JSON.parse函数

还有一种将标准字符串转换为JSON对象的函数是JSON.parse(),使用方式如JSON.parse(str)//其中str就是满足本标题描述的字符串

        var str = '{ "name": "mady", "age": "24" }';
        var obj = JSON.parse(str);
        alert(obj.name);

以上均会输出结果“john”。

此种方式仅支持标准格式:var str='{ "name": "John" }';

参见本例下载包中:JqueryDemo3.html

 

以上结果一致,均输出姓名,如下图:

clip_image002

 

特别注意:如果obj本来就是一个JSON对象,那么使用eval()函数转换后(哪怕是多次转换)还是JSON对象,但是使用parseJSON()函数处理后会有问题(抛出语法异常)。

D:Other方式

 

如果忍不住想犯错,十分十分想解析非标准、非正规字符串,如:

      {name:mady,age:23}

或者

      {name:’mady’,age:23}

以及其他的你能想到的各种本质正确的非法格式,那么有扩展库可以解决

jquery-json 扩展库

下载地址在这里:http://code.google.com/p/jquery-json/

这个库用来扩展 jQuery ,对于 JSON 的使用,扩展了两个函数:toJSONparseJSON

toJSON 函数用来将一个普通的 JavaScript 对象序列化为 JSON 对象。

parseJSON函数用来将一个普通的 JavaScript 对象序列化为 JSON 对象too。

复制代码
      var data=$.toJSON({ x: 2, y: 3 }); 
      var obj = jQuery.parseJSON(data); 
      alert(obj.x); 
      var str = {plugin: 'jquery-json', version: 2.3}; 
      var data2=$.toJSON(str); 
      var obj2 = jQuery.parseJSON(data2); 
      alert(obj2.plugin);
复制代码

以上代码执行结果如:

imageclip_image004

参见本例下载包中:JqueryDemo5.html

 

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

可以使用toJSONString()或者全局方法JSON.stringify()将JSON对象转化为JSON字符串。

例如:

var last=obj.toJSONString(); //将JSON对象转化为JSON字符

或者

var last=JSON.stringify(obj); //将JSON对象转化为JSON字符

alert(last);

三、解析读取JSON

我们通过各种方式将字符串转换为JSON对象后就是解析他了。

如上面的例子:

      var str2 = { "name": "mady", "sex": "man" };

就可以这样读取:

      alert(str2.name);//和C#一样直接往出点…

弹出” mady”。

我们遇到的JSON很少有这么简单的,比如复杂一点的JSON对象如:

      var str={"GetUserPostByIdResult":{"Age":"33","ID":"2server","Name":"mady"}};

解析用:

      alert(str.GetUserPostByIdResult.Name);//一次点不出来,我多点几次

弹出:”mady”。

再再复杂一点的如:

      var data=" { root: [ {'name':'6200','value':'0'}, {'name':'6101','value':'xa'}, {'name':'6102','value':'beijing'}, {'name':'6103','value':'haerbin'}]}";

如果你想单挑的话,解析用:

      alert(dataObj.root[0].name);

弹出:“6200”。

如果你想群挑的话,解析用:

      $.each(dataObj.root, function(index, item) {
            $("#info").append(
                    "<div>" +index+":"+ item.name + "</div>" + 
                    "<div>" +index+":"+ item.value + "</div><hr/>");
        });

其中这个“#info”是个DIV的ID。输入结果如下图:

 

clip_image006

参见本例下载包中:JqueryDemo4.html

注意:本例如果要使用其他转换函数请更改字符串内单引号为双引号,外引号为单引号。

http://files.cnblogs.com/madyina/Json.rar




JS 解析Json 方法

JSON中,有两种结构:对象和数组

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,是理想的数据交换格式

    1. 一个对象以“{”(左括号)开始,“}”(右括号)结束。每个名称后跟一个“:”(冒号);“‘名称/ 之间运用 “,”(逗号)分隔。 名称用引号括起来;值如果是字符串则必须用括号,数值型则不须要。例如:

    var o={"xlid":"cxh","xldigitid":123456,"topscore":2000,"topplaytime":"2009-08-20"}

    2. 数组是值(value)的有序集合。一个数组以“[”(左中括号)开始,“]”(右中括号)结束。值之间运用 “,”(逗号)分隔。

    例如:

    var jsonranklist=[{"xlid":"cxh","xldigitid":123456,"topscore":2000,"topplaytime":"2009-08-20"},{"xlid":"zd","xldigitid":123456,"topscore":1500,"topplaytime":"2009-11-20"}];

JSON对象和JSON字符串之间的相互转换

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

    JSON字符串:

    var str1 = '{ "name": "cxh", "sex": "man" }';

    JSON对象:

    var str2 = { "name": "cxh", "sex": "man" };

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

要运用上面的str1,必须运用下面的要领先转化为JSON对象:

    //JSON字符串转换为JSON对象

    var obj = eval_r('(' + str 1+ ')');

或者

    var obj = str.parseJSON(); //JSON字符串转换为JSON对象

    或者

    var obj = JSON.parse(str); //JSON字符串转换为JSON对象

    然后,就可以这样读取:

    Alert(obj.name);

    Alert(obj.sex);

特别留心:如果obj本来就是一个JSON对象,那么运用 eval()函数转换后(哪怕是多次转换)还是JSON对象,但是运用 parseJSON()函数处理后会有疑问(抛出语法异常)

二、可以运用 toJSONString()或者全局要领JSON.stringify()JSON对象转化为JSON字符串。

例如:

    var last=obj.toJSONString(); //JSON对象转化为JSON字符

    或者

    var last=JSON.stringify(obj); //JSON对象转化为JSON字符

alert(last);

 

    留心:

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


使用Jquery解析Json基础知识

前言 在WEB数据传输过程中,json是以文本,即字符串的轻量级形式传递的,而客户端一般用JS操作的是接收到的JSON对象,所以,JSON对象和JSON字符串之间的相互转换、JSON数据的解析是...
  • zhengbo0
  • zhengbo0
  • 2014年03月21日 15:13
  • 381

Jquery解析json字符串、json数组

Jquery解析json字符串、json数组 解析json字符串、json数组 {"ret": 0, "msg": "", ...
  • u010363836
  • u010363836
  • 2014年09月13日 17:39
  • 3253

jquery parseJSON()方法解析json字符串

在web项目开发中,前端经常需要接收后端传送来的json数据,解析json字符串,再对页面进行渲染。使用jquery解析json字符串通常需要将json字符串转化为javascript的json对象(...
  • u010100724
  • u010100724
  • 2015年08月01日 20:34
  • 10002

jquery解析json异步功能树

1.html代码: 2.定义的json格式:json对象一般用双引号,并且文件编码方式为utf-8 [{ "id":"01", "name":"中国", "items":[{ "...
  • linbooooo1987
  • linbooooo1987
  • 2012年02月05日 19:02
  • 3093

jquery解析JSON数据,异步请求,快速准确处理

乡里亲 2016-11-08 08:50 相信很多朋友在做项目时,会遇到JSON数据处理,而现在对JSON数据的应用也是十分普遍,特别在不同的项中采用同一数据源时,JSON数据的传递更易于理解与使用...
  • u011277123
  • u011277123
  • 2016年11月10日 10:01
  • 185

Jquery解析json字符串及json数组的方法

本文实例讲述了Jquery解析json字符串及json数组的方法。分享给大家供大家参考。具体如下: 解析json字符串、json数组 ...
  • my98800
  • my98800
  • 2016年10月13日 17:05
  • 1129

MVC Newtonsoft.Json解析JSON字符串

using Newtonsoft.Json; using System; using System.Collections.Generic; using System.Web.Mvc; namesp...
  • KingCruel
  • KingCruel
  • 2015年08月20日 16:05
  • 2558

js jquery前台解析json字符串

一、js解析json字符串eval()和JSON.parse()对于服务器返回的JSON字符串,如果jquery异步请求没做类型说明,或者以字符串方式接受,那么需要做一次对象化处理,就是将该字符串放于...
  • jethai
  • jethai
  • 2016年08月28日 14:08
  • 673

jquery解析json数据

[javascript] view plaincopy jquery解析json数据:   var data="    {    root:    [    {...
  • kissdeath
  • kissdeath
  • 2014年01月23日 17:00
  • 3327

jquery解析json使用$.each()

$.post('action.do',null,function(message){ var data=eval("("+message+")"); var html='text'; $....
  • wzy42563
  • wzy42563
  • 2011年09月16日 13:45
  • 404
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:使用Jquery解析Json基础知识
举报原因:
原因补充:

(最多只允许输入30个字)