JSON
2016-01-18 15:00
676 查看
1、JSON概述
JSON(JavaScript Object Notation) ,JavaScript对象标记,是一种轻量级的数据交换格式。使用字符串来表示Javascript对象,例如可以在Servlet中发送一个JSON格式的字符串给客户端Javascript,Javascript可以执行这个字符串,得到一个Javascript对象。XML也可以用来做为数据交换,前面已经学习过在Servlet中发送XML给Javascript,然后Javascript再去解析XML。
json-lib核心jar包:
● json-lib.jar
json-lib的依赖jar包有:
● commons-lang.jar
● commons-beanutils.jar
● commons-logging.jar
● commons-collections.jar
● ezmorph.jar
2、JSON对象语法
(1)JSON 语法:
● 数据在名称/值对中;● 数据由逗号分隔;
● 花括号保存对象;
● 方括号保存数组。
<pre name="code" class="javascript"><span style="font-size:18px;">var person = {"name":"zhangSan", "age":"18", "sex":"male"}; alert(person.name + ", " + person.age + ", " + person.sex);</span>
注意,key要在双引号中!
(2)JSON值:
● 数字(整数或浮点数);● 字符串(在双引号中);
● 逻辑值(true 或 false);
● 数组(在方括号中) ;
● 对象(在花括号中);
● null。
<pre name="code" class="javascript"><span style="font-size:18px;">var person = {"name":"zhangSan", "age":"18", "sex":"male", "hobby":["cf", "sj", "ddm"]}; alert(person.name + ", " + person.age + ", " + person.sex + ", " + person.hobby);</span>
带有方法的JSON对象:
<pre name="code" class="javascript"><span style="font-size:18px;">var person = {"name":"zhangSan", "getName":function() {return this.name;}}; alert(person.name); alert(person.getName());</span>
3、JSON与XML比较
● 可读性:XML胜出;● 解码难度:JSON本身是JS对象,所以简单很多;
● 流行度:XML已经流行好多年,但在AJAX领域,JSON更受欢迎。
4、把Java对象转换成JSON对象
apache提供的json-lib小工具,它可以方便的使用Java语言来创建JSON字符串。也可以把JavaBean转换成JSON字符串。json-lib中的核心类:
● JSONObject;
● JSONArray;
(1)JSONObject
JSONObject类本身是一个Map:<pre name="code" class="javascript"><span style="font-size:18px;"> JSONObject jo = new JSONObject(); jo.put("name", "zhangSan"); jo.put("age", "18"); jo.put("sex", "male"); System.out.println(jo.toString());</span>
输出为:{"name":"zhangSan","age":"18","sex":"male"}。
<pre name="code" class="javascript"><span style="font-size:18px;"> Person person = new Person("liSi", 18, "female"); JSONObject jo = JSONObject.fromObject(person); //把javabean对象转换为json System.out.println(jo.toString());</span>
<pre name="code" class="javascript"><span style="font-size:18px;"> Map map = new HashMap(); map.put("name", "wangWu"); map.put("age", "81"); map.put("sex", "male"); JSONObject jo = JSONObject.fromObject(map); //把map转换为json System.out.println(jo.toString());</span>
<pre name="code" class="javascript"><span style="font-size:18px;"> String xml = "<person><name>zhaoLiu</name><age>59</age><sex>female</sex></person>"; XMLSerializer serial = new XMLSerializer(); JSONObject jo = (JSONObject)serial.read(xml);//把xml转换为json,需要导入xom-1.1.jar包 System.out.println(jo.toString());</span>
(2)JSONArray
JSONArray本身是一个List,所以使用起来很方便:<pre name="code" class="javascript"><span style="font-size:18px;"> JSONArray ja = new JSONArray(); Person p1 = new Person("zhangSan", 18, "male"); Person p2 = new Person("liSi", 23, "female"); ja.add(p1); ja.add(p2); System.out.println(ja.toString());</span>
<pre name="code" class="javascript"><span style="font-size:18px;"> Person p1 = new Person("zhangSan", 18, "male"); Person p2 = new Person("liSi", 23, "female"); List<Person> list = new ArrayList<Person>(); list.add(p1); list.add(p2); JSONArray ja = JSONArray.fromObject(list); //把list转换为JSONArray System.out.println(ja.toString());</span>
<span style="font-size:18px;"> Person p1 = new Person("zhangSan", 18, "male"); Person p2 = new Person("liSi", 23, "female"); Person[] persons = {p1, p2}; JSONArray ja = JSONArray.fromObject(persons); System.out.println(ja.toString());</span>
5、JS解释服务器发送过来的JSON字符
服务器发送过来JSON字符串后,客户端需要对其进行解析。这时客户端需要使用eval()方法对JSON字符串进行执行!但要注意,eval()方法在执行JSON时,必须把JSON字符串使用一对圆括号括起来。<span style="font-size:18px;">var json = "{\"name\":\"zhangSan\", \"age\":\"18\", \"sex\":\"male\"}"; var person = eval("(" + json + ")"); alert(person.name + ", " + person.age + ", " + person.sex);</span>
相关文章推荐
- DOM事件探秘之三-键盘事件
- jsonp 使用记录(二)跨域设置cookie
- 理解JavaScript中Promise的使用
- JS日期:根据出生日期 得到周岁年龄
- 使用rapidjson生成json串
- js split 的用法和定义 js split分割字符串成数组的实例代码
- .net 接口返回json格式示例
- jsonp 使用简单记录(一)
- 读写json中文ASCII乱码的问题
- 模仿console自写函数打印js的对象
- angular js过滤器
- jsp页面格式化日期 用jstl的fmt:formatDate 标签
- jsp 输出word文件默认页面显示
- 你不知道的高性能JAVASCRIPT
- javascript 自己主动绑定JS callback 的方法函数
- javascript中0级DOM和2级DOM事件模型浅析
- 理解js中的闭包
- 关于js单线程的问题
- JS 一定要放在 Body 的最底部么?聊聊浏览器的渲染机制
- [JS脚本]ajax status 错误定义