struts2 中怎么写ajax
时间: 2024-03-15 09:19:56 浏览: 59
在 Struts2 中,可以使用 jQuery 或其他 JavaScript 框架来实现 AJAX。以下是一个基本的例子:
1. 在 JSP 页面中,引入 jQuery 库:
```
<script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
```
2. 在 JSP 页面中,编写一个按钮或链接,用于触发 AJAX 请求:
```
<button id="ajaxBtn">点击发送 AJAX 请求</button>
```
3. 在 JSP 页面中,编写一个 div,用于显示 AJAX 响应结果:
```
<div id="resultDiv"></div>
```
4. 在 JSP 页面中,使用 jQuery 发送 AJAX 请求:
```
<script>
$(document).ready(function() {
$("#ajaxBtn").click(function() {
$.ajax({
url: "ajax-example.action",
type: "POST",
dataType: "text",
success: function(result) {
$("#resultDiv").html(result);
},
error: function(xhr, status, error) {
$("#resultDiv").html("AJAX 请求出错:" + error);
}
});
});
});
</script>
```
在上面的代码中,我们使用 jQuery 的 `$.ajax()` 函数来发送 AJAX 请求。其中,`url` 参数指定了请求的地址,`type` 参数指定了请求的类型(POST 或 GET),`dataType` 参数指定了响应数据的类型(text、json 等),`success` 参数指定了请求成功后的回调函数,`error` 参数指定了请求失败后的回调函数。
在 Struts2 中,我们可以通过在 `struts.xml` 文件中配置 Action,指定 Action 的返回类型为 `text/plain`,从而返回 AJAX 响应数据。例如:
```
<action name="ajax-example" class="com.example.AjaxExampleAction">
<result name="success" type="text/plain">${ajaxResult}</result>
</action>
```
在上面的代码中,`com.example.AjaxExampleAction` 是一个 Struts2 Action 类,响应结果存储在 Action 的属性 `ajaxResult` 中,返回类型为 `text/plain`。在 Action 中,我们可以使用 Struts2 提供的 `ServletResponseAware` 接口来获取响应对象,从而将响应数据写入响应流中。例如:
```
public class AjaxExampleAction implements Action, ServletResponseAware {
private String ajaxResult;
private HttpServletResponse response;
public String execute() throws Exception {
// 处理 AJAX 请求
ajaxResult = "Hello, AJAX!";
return SUCCESS;
}
public void setServletResponse(HttpServletResponse response) {
this.response = response;
}
public String getAjaxResult() {
return ajaxResult;
}
}
```
在上面的代码中,`ServletResponserAware` 接口的 `setServletResponse()` 方法会在 Action 中自动注入响应对象,我们可以通过该对象获取响应流,将响应数据写入流中。在本例中,我们将响应数据存储在 `ajaxResult` 属性中,然后在 `struts.xml` 文件中使用 `${ajaxResult}` 来输出响应数据。
阅读全文