可能会有问题,但是文章不错,谢谢原作!
******************************************************
JSON介绍
一、
JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。易于人阅读和编写。同时,也易于机器解析和生成。
二、JSON数据格式解析:
和XML一样,JSON也是基于存文本的数据格式。您可以用JSON传输一个简单的String、Number、Boolean,也可以传输一个数组或者一个复杂的Object对象。
例如:
1、用JSON表示一个简单String“abc”,其格式为:”abc”。除了字符“,\,/和一些控制符(\b,\n,\t等)需要编码外,其他Unicode字符可以直接输出。
2、用JSON表示一个数组对象,使用“[ ]“包含所有元素,每个元素用逗号分隔,元素可以使任意的value,例如,一下数组包含了一个String、Number、Boolean、和一个null:
[“abc”,123,false,null]。
3、Object对象在JSON中用“{}“包含一系列无序的Key-Value键值对表示,实际上此处的Object相当于Java中的Map。注意Key只能用String表示。例如:一个Address对象包含如下Key-Value:{“city”:”beijing”,”street”:”chaoyang”,”postcode”:100025}。
三、JAVASCRIPT处理JSON数据
Function demo(){
var v={“name”:”SMITH”,”address”:{“city”:”beijing”,”postcode”:100025}};
document.write(v.name);
document.write(v.address.city);
}
四:JSON和XML的比较
XML和JSON都是用结构化方法来标记数据,下面来做一个简单的比较。
<?xml version=”1.0” encoding=”utf-8”?>
<country>
<name>中国</name>
<province>
<name>黑龙江</name>
<citys>
<city>哈尔滨</city>
<city>大庆</city>
</citys>
</province>
</country>
用JSON表示如下:
{
name:”中国”,
province:[
{
Name:”黑龙江”,citys:{“哈尔滨”,”大庆”}
}
]
}
XML比JSON更有可读性。不过,我们读起来费解的语言,恰恰是适合机器阅读的。编写的手写难度来说,XML还是舒服一些,好读当然就好写。不过写出来的字符JSON就明显少很多。去掉空白制表以及换行的话,JSON就是有用数据,而XML却包含很多重复的标记字符。
五、下面列举两个对象:JSONArray和JSONObject
在写有关于JSON的程序时首先要加入六个JAR包:commons-beanutils-1.7.0.jar、commons-collections.jar、commons-lang-2.2.jar、ezmorph-1.0.4.jar、json-lib-2.1-jdk15.jar、xom-1.1d2.jar
(1)JSONArray
例子:
List list = new ArrayList();
list.add("a");
list.add("b");
JSONArray jso = JSONArray.fromObject(list);
System.out.println(list);
输出的结果是:[“a”,”b”] 。
(2)JSONObject
例子:
Map map = new HashMap();
map.put( "int",new Integer(1) );
map.put( "arr",new String[]{"a","b"} );
map.put( "func","function(i){ return this.arr; }");
JSONObject json = JSONObject.fromObject( map );
System.out.println( json );
输出的结果是:{"arr":["a","b"],"int":1,"func":function(i){return this.arr; }}
(3)JSONObject toXML
例子:
JSONObject json =JSONObject.fromObject("{\"name\":\"json\",\"bool\":true,\"int\":1}");
XMLSerializer xmlSerializer = new XMLSerializer();
String xml = xmlSerializer.write(json);
System.out.println(xml);
XML to JSONObject
例子:
String xmls = "<?xml version='1.0'encoding='UTF-8'?><o><int type='number'>1</int>" +"<name type='string'>json</name></o>";
XMLSerializer xmlSerializer = new XMLSerializer();
JSON json = xmlSerializer.read(xmls); System.out.println(json.toString(2) );
六、下面列举AJAX和JSON的例子
1、环境struts、hibernate、JSON、AJAX
2、首先,加载struts和hibernate框架,然后再把JSON的JAR包放到lib下。
创建一个Action:
Action的内容如下:
PrintWriter out = response.getWriter();
JSONObject obj = new JSONObject();
JSONArray js = new JSONArray();
//这里的数据封装是从数据库查询来的
MesDao md = new MesDao();
List list = md.findMess();
for(int i=0;i<list.size();i++){
JSONObject objtemp = new JSONObject();
TMessage tm = (TMessage) list.get(i);
objtemp.put("id",tm.getId());
objtemp.put("name",tm.getName());
js.add(objtemp);
}
obj.put("js",js);
out.print(obj.toString());
然后,创建一个JSP页面:
其内容如下:
<script type="text/javascript"src="prototype1.4.js"></script>
<script type="text/javascript"src="toolpro.js"></script>
<script type="text/javascript">
function demo(){
new Ajax.Updater("content","test.do");
}
</script>
<a href='javascript:getcomplex()'>获取数据</a>
<div id="content">
正在获取内容...
</div>
然后创建toolpro.js toolpro.js的内容如下: function getcomplex(){ var url = 'test.do'; var ajax = new Ajax.Request(url,{method:'post',Complete:showcomplex}); } function showcomplex(dataResponse) { var data = eval('(' + dataResponse.responseText + ')'); var str=''; for(var i=0;i<data.js.length;i++) { str+='<ul>'; str+='<li>'+data.js.id+'</li>'; str+='<li>'+data.js.name+'</li>'; str+='</ul>'; } document.getElementById("content").innerHTML=str; }
原文链接:https://www.f2er.com/json/290035.html