AJAX快速入门-GET(PROJECT02_DAY01_01)

2. AJAX快速入门

2.1 AJAX请求响应过程分析

所有的 AJAX请求都会基于DOM(HTML元素)事件,通过XHR(XMLHttpRequest)对象实现与服务端异步通讯局部更新,如图-4所示:
在这里插入图片描述
图-4

2.2 AJAX编程基本步骤分析

第一步:基于dom事件创建XHR对象(XMLHttpRequest对象)
第二步:注册XHR对象状态监听,通过回调函数处理状态信息
第三步:创建与服务端的连接
第四步:发送异步请求实现与服务端的通讯
第五步:通过回调(callback)函数,获得响应结果并进行数据更新.(非阻塞)

  • Controller 层代码:
//http://localhost/activity/activity_list 
@RequestMapping("activity_list") 
public String doActivityListUI(){ 
	return "activity_list"; 
}

并通过@ResponseBody 注解对方法进行描述,用于告诉 SpringMVC 将方法返回值转换为 json 格式的字符串。

//http://localhost/activity/doFindActivitys
@RequestMapping("doFindActivitys")
@ResponseBody //告诉 spring mvc 将返回值转换 json 格式字符串
public List<Activity> doFindActivitys(){
	List<Activity> list=activityService.findActivitys(); 
	return list;
}

2.3 AJAX请求响应编程操作实践

2.3.1 AJAX GET 请求操作实现

课堂练习:基于时序图分析,进行代码设计和实现,如图-5所示:
在这里插入图片描述
图-5

图-5中涉及到的相关代码参考如下:
基于 AJAX技术中的 XMLHttpRequest 对象,向服务端发起异步 GET请求,关键代码分析如下:

function doAjaxGet(url,params,callback){//没有参数可以不写
     //1.创建XmlHttpRequest对象
     var xhr=new XMLHttpRequest();
     //2.设置状态监听,监听XmlHttpRequest对象与服务端通讯的过程(例如连接是否建立,请求是否在处理,响应是否已产生)
     xhr.onreadystatechange=function(){//监听函数
         //基于xhr对象获取的通讯状态,对响应数据进行处理
         if(xhr.readyState==4&&xhr.status==200){//4 表示通讯结束,200表示服务端响应ok
        	//服务端响应的结果会传递给XHR对象,我们可以借助responseText获取响应结果
            callback(xhr.responseText);
         }
     }
    //3.创建与服务端的连接
    xhr.open("GET",url+"?"+params,true);//true表示异步
    //4.发送请求
    xhr.send(null); //Get请求,send方法不传内容
    //5.对响应结果进行处理(在回调函数中处理)。
}

向服务端发送异步请求获取数据

//通过如下函数向服务端发送异步请求获取activity数据并更新到页面上
<script type="text/javascript">
function doGetActivitys() {
	//1.定义请求参数
	var params = "";
	//2.定义请求的url
	var url = "doFindActivitys";//没有加/,因为是相对路径
	//3.发送异步请求获取服务端资源并更新到页面上
	doAjaxGet(url, params, function(result) {
		//在浏览器控制台输出 result
		//console.log(result);
		doHandleResponseResult(result);
	});
}
doGetActivitys();
</script>

因为从后台传来的数据为字符串,并不能获取其中数据,所以需要将其转为对象, 转为对象后才能够获取其中数据:
在这里插入图片描述
在这里插入图片描述

通过 doHandleResponseResult 方法将 AJAX 获得的响应结果呈现在页面上。

 function doHandleResponseResult(result){
       //1.将json格式字符串转换为json格式的JS对象(字符串无法直接提取内容)
       var jsonObj=JSON.parse(result);//JSON为JS中的一个类
       //2.将json对象中的数据更新到页面上
       //2.1 迭代jsonObj对象中的数据,并将数据拼接到tr字符串中
       var trs="";
       for (var i=0;i<jsonObj.length;i++) {
				trs += "<tr>" + 
				"<td>" + jsonObj[i].id + "</td>" + 
				"<td>" + jsonObj[i].title + "</td>" + 
				"<td>" + jsonObj[i].category + "</td>" + 
				"<td>" + new Date(jsonObj[i].startTime).toLocaleString() + "</td>" + 
				"<td>" + new Date(jsonObj[i].endTime).toLocaleString() + "</td>" + 
				"<td>" + (jsonObj[i].state ? "进行中" : "已结束") + "</td>" + 
				"<td>delete</td>" +
				"</tr>"
			}
			//2.2将字符串以html的形式更新到tbody的位置上
			var tBody =document.getElementById("tbodyId");
			tBody.innerHTML=trs;
   }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值