1、jQuery异步请求简述
jQuery的异步请求也称之为快速通信机制,主要包括$.get,$.post,$.getJSON,$.ajax等种类角度,底层封装了javaScript的XMLHttpRequest对象,且解决了浏览器之间的差异性,兼容性较好,使用更加的遍历
2、$.get使用方式
2.1、基本用法
【完整写法】
//test.do请求地址 {}:请求参数,使用json字符串 function:回调函数
$.get("test.do",{"username":"晓春","userid":"1001"},function(data){
//回调函数
});
【其他写法】
如果只需要请求不会需要回调函数,或者只需要回调不需要请求参数也可以写成如下写法
//1、直接发送get请求到test.do
$.get("test.do");
//2、直接发送请求并携带json参数
$.get("test.do",{"username":"晓春","userid":"1001"});
//3、直接请求,并获取回调函数
$.get("test.do",function(data){
//回调函数
});
2.2 项目案例-使用servlet进行测试
【前端jQuery请求】
jQuery的使用需要导入jquery包
<script type="text/javascript" src="js/jquery-2.1.1.js"></script>
<script type="text/javascript">
$.get("test.do",{"username":"晓春","userid":"1001"},function(data){
//data的数据为: {"userid":"1001","username":"晓春"}
//parseJSON()函数用于将格式完好的JSON字符串转为与之对应的JavaScript对象
var obj = $.parseJSON(data);
//转化之后通过obj直接获取json中的属性名称即可,如obj.id输出为1001
alert("===1==="+ obj.userid);
});
</script>
【后端获取结果并返回值】
如果使用springmvc用法相同,可以通过springmvc提供的@ResponseBody返回json数据
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.out.println("================test.do====================");
response.setContentType("text/html;charset=utf-8");
String userid=request.getParameter("userid");
String username=request.getParameter("username");
//获取用户名和密码并返回json字符串 其他说明:\":使用转义字符返回双引号
response.getWriter().print("{\"username\":\",\"userid\":\""+userid+"\"\",\"userid\":\""+userid+"\",}");
}
3、$.post使用方法
$.post使用与$.get使用基本相似,可以将上面案例直接复制修改成$.post即可。
4、$.getJSON使用方法
需要注意的是$.getJSON接口的返回值比较特殊,返回值需要是jsonObject
JSONObject对象的使用需要用到指定包信息,如下是包下载地址
链接:https://pan.baidu.com/s/1DTBOEQFO1Ty2soLgSNThgw
提取码:uk0c
【前端用法】
/* 需要返回指定类型的数据 --- JSON对象 */
$.getJSON("test.do",{"username":"晓春","userid":"1001"},function(data){
//data返回值类型为[object object],结果可以通过data.属性直接获取到
alert(data.stu.stu_id);
});
【后端用法】
JSONObject 对象的使用需要下载对应的包
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
Map<String, Object> map=new HashMap<>();
map.put("stu_id", "1001");
map.put("code", "200");
//JSONObject可以将Map类型的参数解析成json对象,并通过response返回
JSONObject obj1=new JSONObject(map);
response.getWriter().print(obj1.toString());
}
5、$.ajax的使用
【ajax基本参数配置和使用】
$.ajax({
type:"get",//请求类型get或post
url:"test.do",//请求地址
cache:false,//去除请求缓存
dataType:"text",//与后端数据交互类型
data:{"userid":"1002","username":"十一郎"},
success:function(data){//请求成功之后的回调函数
alert("====1===="+data);
var obj = $.parseJSON(data);
alert("===2==="+obj.userid);
}
});
【后端用法】
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.out.println("================test.do====================");
response.setContentType("text/html;charset=utf-8");
String userid=request.getParameter("userid");
String username=request.getParameter("username");
//获取用户名和密码并返回json字符串 其他说明:\":使用转义字符返回双引号
response.getWriter().print("{\"username\":\",\"userid\":\""+userid+"\"\",\"userid\":\""+userid+"\",}");
}