使用Jquery解析Json基础知识
来源:互联网 发布:淘宝坑位产值计算公式 编辑:程序博客网 时间:2024/06/05 09:24
在WEB数据传输过程中,json是以文本,即JSON字符串形式传递的,而客户端接收到的是JSON对象,所以,JSON对象和JSON字符串之间的相互转换、JSON数据的解析是关键。
先明确2个概念例如:
JSON字符串:
var str1 = '{ "name": "deyuyi", "sex": "man" }';
JSON对象:
<strong>var str2 = { "name": "deluyi", "sex": "man" };</strong>
可以简单这样理解:
JSON对象是直接可以使用JQuery操作的格式,如C#中可以用对象(类名)点出属性(方法)一样;
JSON字符串仅仅只是一个字符串,一个整体,不截取的话没办法取出其中存储的数据,不能直接使用,除非你只想alert()他;
一、JSON字符串转换为JSON对象
要使用上面的str1,必须使用下面的方法先转化为JSON对象:
A. 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" }';
B:eval函数
eval函数可以直接将本质符合或者近似符合JSON格式的字符串转换为JSON对象,使用方式如:
eval('(' + str + ')'); //其中str就是满足本标题描述的字符串
//由JSON字符串转换为JSON对象 var str='{ "name": "John" }'; var obj = eval('(' + str + ')'); alert( obj.name);
以上均会输出结果“john”。
Eval方式可以转换以下标准和非标准格式字符串:
var str="{ 'name': 'John' }";var str2='{ "name": "John" }';var str3="{ name: 'John' }";
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" }';
特别注意:如果obj本来就是一个JSON对象,那么使用eval()函数转换后(哪怕是多次转换)还是JSON对象,但是使用parseJSON()函数处理后会有问题(抛出语法异常)。
二、将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。输入结果如下图:
注意:本例如果要使用其他转换函数请更改字符串内单引号为双引号,外引号为单引号。
- 使用Jquery解析Json基础知识
- 使用Jquery解析Json基础知识
- 使用Jquery解析Json基础知识
- 使用Jquery解析Json基础知识
- 使用Jquery解析Json基础知识
- 使用Jquery解析Json基础知识
- 使用Jquery解析Json基础知识
- 使用Jquery解析Json基础知识
- 使用Jquery解析Json基础知识
- 使用Jquery解析Json基础知识
- 使用Jquery解析Json基础知识
- 使用Jquery解析Json基础知识
- 使用Jquery解析Json基础知识
- 使用jQuery解析JSON数据
- jquery解析json使用$.each()
- 使用jQuery解析JSON数据
- 使用jQuery解析JSON数据
- 使用jQuery解析JSON数据
- C语言 编写递归函数实现厄密多项式计算。
- MapReduce工作原理图文详解
- Android系统的进程分类
- SSH框架实现MYSQL数据库备份与还原
- web项目--BBS之从数据库查询动态生成版块信息问题分析和小结
- 使用Jquery解析Json基础知识
- Hibernate基础
- 【BestCoder】36 B Gunner(哈希)
- android开发 - Application类
- C++ Primer Plus第六版编程练习9.4解答
- 求最大子数组和
- Linux协议栈-netfilter(5)-iptables
- 设计模式之--Facade模式
- 【SeedCoder 2015年热身】写在最前面的话