Struts学习总结:AJAX与数据发送方式

需积分: 9 2 下载量 28 浏览量 更新于2024-08-23 收藏 330KB PPT 举报
"Struts学习总结,包括发送数据的三种形式以及AJAX技术的详细解析" 在Web开发中,Struts框架是一种广泛使用的MVC(Model-View-Controller)架构,它帮助开发者构建可维护性和可扩展性高的应用程序。在本文中,我们将探讨Struts框架中的数据发送方式以及AJAX技术的基础知识。 首先,我们来看发送数据的三种主要形式: 1. 表单序列化(serialize()):当表单元素拥有name属性时,可以使用jQuery的serialize()方法将表单数据转换为URL编码格式。例如,HTML代码中定义了一个包含用户名输入的表单,通过`$("#form1").serialize()`可以获取到表单数据,然后使用`$.get(url, data, function(text) {})`进行异步GET请求。 2. 键值对形式:直接以name="aa"&pwd="123"的方式,通过URL或POST请求发送数据。这种方式适用于简单的参数传递,例如在GET请求中附加在URL后面,或者在POST请求中作为请求体。 3. JSON对象:使用JavaScript对象表示法,如{name:"aa",pwd:"123"},适合发送复杂的数据结构。通常,JSON数据会通过POST请求发送,并在服务器端进行解析。 接下来,我们深入了解一下AJAX技术: AJAX(Asynchronous JavaScript And XML)是一种用于创建快速、动态网页的技术,它允许在不重新加载整个页面的情况下与服务器交换数据并更新部分网页内容。AJAX的核心是JavaScript和XMLHttpRequest对象。 XMLHttpRequest对象是实现AJAX的关键,其主要方法包括: - open():这个方法用于打开一个新的HTTP连接,接受三个参数:请求类型(get/post)、请求的URL和一个布尔值,表示是否异步执行。默认情况下,请求是异步的(true)。 - send():用于发送HTTP请求。对于GET请求,数据为空(send(null));而对于POST请求,数据需要作为参数传递,如send("uname=" + name)。 此外,XMLHttpRequest对象还有几个重要的属性: - readyState:表示请求的状态,从0到4,分别对应请求的不同阶段。 - status:返回HTTP状态码,200表示成功,404表示找不到资源。 - responseText和responseXML:分别用于获取响应数据的文本和XML格式。 - onreadystatechange:当readyState属性改变时,会触发这个事件,常用来设置回调函数以处理服务器返回的数据。 AJAX使用实例: 1. 创建XMLHttpRequest对象:`var xmlHttpRequest = new XMLHttpRequest();` 2. 设置请求地址和方法:`xmlHttpRequest.open("GET", url, true);` 3. 发送请求:`xmlHttpRequest.send(null);` 4. 监听状态变化并处理响应:`xmlHttpRequest.onreadystatechange = function() { if (xmlHttpRequest.readyState == 4 && xmlHttpRequest.status == 200) { // 处理数据 } };` 通过这些基本的AJAX操作,开发者可以在不刷新整个页面的情况下,实现用户界面的动态更新,提升用户体验。在Struts框架中,结合AJAX技术,可以构建出更加高效和互动的Web应用。