JSON&&AJAX
一、JSON
1.1 json简介
JSON (JavaScript Object Notation) 是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。JSON采用完全独立于语言的文本格式,而且很多语言都提供了对 json 的支持(包括 C, C++, C#, Java, JavaScript, Perl, Python等)。 这样就使得 JSON 成为理想的数据交换格式。
json 是一种轻量级的数据交换格式。
轻量级指的是跟 xml 做比较。数据交换指的是客户端和服务器之间业务数据的传递格式。
1.2 JSON 在 JavaScript 中的使用
json 是由键值对组成,并且由花括号(大括号)包围。每个键由引号引起来,键和值之间使用冒号进行分隔,多组键值对之间进行逗号进行分隔。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| var jsonObj = { "key1":12, "key2":"abc", "key3":true, "key4":[11,"arr",false], "key5":{ "key5_1" : 551, "key5_2" : "key5_2_value" }, "key6":[{ "key6_1_1":6611, "key6_1_2":"key6_1_2_value" },{ "key6_2_1":6621, "key6_2_2":"key6_2_2_value" }] };
|
json 访问示例:
json 中的 key 访问就跟访问对象的属性一样: json 对象.key
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
| alert(typeof(jsonObj)); alert(jsonObj.key1); alert(jsonObj.key2); alert(jsonObj.key3); alert(jsonObj.key4);
for(var i = 0; i < jsonObj.key4.length; i++) { alert(jsonObj.key4[i]); } alert(jsonObj.key5.key5_1); alert(jsonObj.key5.key5_2); alert( jsonObj.key6 );
var jsonItem = jsonObj.key6[0];
alert( jsonItem.key6_1_2 );
|
json 的两个常用方法
json 的存在有两种形式。
一种是:对象的形式存在,我们叫它 json 对象。
一种是:字符串的形式存在,我们叫它 json 字符串。
一般我们要操作 json 中的数据的时候,需要 json 对象的格式。
一般我们要在客户端和服务器之间进行数据交换的时候,使用 json 字符串。
JSON.stringify() 把 json 对象转换成为 json 字符串
JSON.parse() 把 json 字符串转换成为 json 对象
1 2 3 4 5 6 7
| var jsonObjString = JSON.stringify(jsonObj); alert(jsonObjString)
var jsonObj2 = JSON.parse(jsonObjString); alert(jsonObj2.key1); alert(jsonObj2.key2);
|
1.3 JSON 在 java 中的使用
javaBean 和 json 的互转
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| @Test public void test1(){ Person person = new Person(1,"国哥好帅!"); Gson gson = new Gson(); String personJsonString = gson.toJson(person); System.out.println(personJsonString); Person person1 = gson.fromJson(personJsonString, Person.class); System.out.println(person1); }
|
List 和 json 的互转
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| @Test public void test2() { List<Person> personList = new ArrayList<>(); personList.add(new Person(1, "国哥")); personList.add(new Person(2, "康师傅")); Gson gson = new Gson(); String personListJsonString = gson.toJson(personList); System.out.println(personListJsonString); List<Person> list = gson.fromJson(personListJsonString, new PersonListType().getType()); System.out.println(list); Person person = list.get(0); System.out.println(person); }
|
map 和 json 的互转
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| @Test public void test3(){ Map<Integer,Person> personMap = new HashMap<>(); personMap.put(1, new Person(1, "国哥好帅")); personMap.put(2, new Person(2, "康师傅也好帅")); Gson gson = new Gson(); String personMapJsonString = gson.toJson(personMap); System.out.println(personMapJsonString); PersonMapType().getType()); Map<Integer,Person> personMap2 = gson.fromJson(personMapJsonString, new TypeToken<HashMap<Integer,Person>>(){}.getType()); System.out.println(personMap2); Person p = personMap2.get(1); System.out.println(p); }
|
二、AJAX请求
2.1 AJAX简介
AJAX 即“Asynchronous Javascript And XML”(异步 JavaScript 和 XML),是指一种创建交互式网页应用的网页开发技术。
ajax 是一种浏览器通过 js 异步发起请求,局部更新页面的技术。
Ajax 请求的局部更新,浏览器地址栏不会发生变化
局部更新不会舍弃原来页面的内容
2.2 原生 AJAX 请求的示例

2.3 jQuery 中的 AJAX 请求

1 2 3 4 5 6 7 8 9 10 11 12 13 14
| $("#ajaxBtn").click(function(){ $.ajax({ url:"http://localhost:8080/16_json_ajax_i18n/ajaxServlet", data:{action:"jQueryAjax"}, type:"GET", success:function (data) { $("#msg").html("编号:" + data.id + " , 姓名:" + data.name); }, dataType : "json" }); });
|
$.get 方法和$.post 方法
url :请求的 url 地址
data :发送的数据
callback :成功的回调函数
type :返回的数据类型
1 2 3 4 5 6 7 8 9 10 11 12
| $("#getBtn").click(function(){ $.get("http://localhost:8080/16_json_ajax_i18n/ajaxServlet","action=jQueryGet",function (data) { $("#msg").html(" get 编号:" + data.id + " , 姓名:" + data.name); },"json"); });
$("#postBtn").click(function(){ $.post("http://localhost:8080/16_json_ajax_i18n/ajaxServlet","action=jQueryPost",function (data) { $("#msg").html(" post 编号:" + data.id + " , 姓名:" + data.name); },"json"); });
|
$.getJSON 方法
url 请求的 url 地址
data 发送给服务器的数据
callback 成功的回调函数
1 2 3 4 5 6 7
| $("#getJSONBtn").click(function(){ $.getJSON("http://localhost:8080/16_json_ajax_i18n/ajaxServlet","action=jQueryGetJSON",function (data) { $("#msg").html(" getJSON 编号:" + data.id + " , 姓名:" + data.name); }); });
|
表单序列化 serialize()serialize()可以把表单中所有表单项的内容都获取到,并以 name=value&name=value 的形式进行拼接
1 2 3 4 5 6 7
| $("#submit").click(function(){
$.getJSON("http://localhost:8080/16_json_ajax_i18n/ajaxServlet","action=jQuerySerialize&" + $("#form01").serialize(),function (data) { $("#msg").html(" Serialize 编号:" + data.id + " , 姓名:" + data.name); }); });
|