Struts2 Ajax

基于不重新发明轮子的原则,Struts 2并没有开发新的AJAX框架,而是使用时下Java EE平台中比较流行的AJAX框架——Dojo和DWR。
最近在Musachy Barroso等同志的无私奉献下,开发了Struts 2的JSON插件(Plugin),极大地方便了我们输出JSON结果(Result)。这些框架都是开发Ajax不错的选择,项目中可选择使用。

一、使用Ajax主题提交表单

1、JSP页面

Xml代码 复制代码
  1. <s:head theme="ajax"/>  
  2. <div id="show">原始内容</div>  
  3. <s:form action="deal" method="post" theme="ajax">    
  4.      <s:datetimepicker name="chooseDate" label="日期选择"/>  
  5.      <s:submit targets="show" loadingText="请等待,提交中..."/>  
  6. </s:form>  
<s:head theme="ajax"/> <div id="show">原始内容 <s:form action="deal" method="post" theme="ajax"> <s:datetimepicker name="chooseDate" label="日期选择"/> <s:submit targets="show" loadingText="请等待,提交中..."/> </s:form>

 

2、Action配置

Xml代码 复制代码
  1. <action name="deal" class="com.xy.struts2.DealWithParams">  
  2.      <!-- 使用Ajax主题提交后必须返回一个视图 -->  
  3.     <result name="success">/AjaxResult.jsp</result>  
  4. </action>  
<action name="deal" class="com.xy.struts2.DealWithParams"> <!-- 使用Ajax主题提交后必须返回一个视图 --> <result name="success">/AjaxResult.jsp</result> </action>

 

3、AjaxResult

Xml代码 复制代码
  1. <%@ page language="java" pageEncoding="GBK"%>  
  2. <%@ taglib prefix="s" uri="/struts-tags" %>  
  3. <%   
  4.     //设置页面不缓存   
  5.     request.setAttribute("decorator","none");   
  6.     response.setHeader("Cache-Control","no-cache");   
  7.     response.setHeader("Pragma","no-cache");   
  8.     response.setDateHeader("Expires",0);   
  9.  %>  
  10.  <!-- 下面是Action返回页面的数据 -->  
  11.  <s:property value="chooseDate"/>  
  12.  <s:property value="msg"/>  
<%@ page language="java" pageEncoding="GBK"%> <%@ taglib prefix="s" uri="/struts-tags" %> <% //设置页面不缓存 request.setAttribute("decorator","none"); response.setHeader("Cache-Control","no-cache"); response.setHeader("Pragma","no-cache"); response.setDateHeader("Expires",0); %> <!-- 下面是Action返回页面的数据 --> <s:property value="chooseDate"/> <s:property value="msg"/>

 

4、Action

代码略。

 

5、小结

利用Struts2整合的Ajax主题,可用实现表单异步提交,但是必须使用一个额外的视图来接受数据,有点麻烦。

 

二、使用JSON插件开发Ajax

JSON插件提供了一种名为json的ResultType,一旦为某个Action指定了一个类型为json的Result,则该Result无需映射到任何视图资源。因为JSON插件会负责将Action里的状态信息序列化成JSON格式的数据,并将该数据返回给客户端页面的JavaScript。

 

  简单地说,JSON插件允许我们在JavaScript中异步调用Action,而且Action不再需要使用视图资源来显示该Action里的状态信息,而是由JSON插件负责将Action里的状态信息返回给调用页面——通过这种方式,就可以完成Ajax交互。

 

  Struts2提供了一种可插拔方式来管理插件,安装Struts2的JSON插件与安装普通插件并没有太大的区别,一样只需要将Struts2插件的JAR文件复制到Web应用的WEB-INF/lib路径下即可。 

 

(1)将json-plugin.jar文件复制到Web应用的WEB-INF路径下,即可完成JSON插件的安装。

 

(2)把JSON.js、prototype-1.4.0.js复制到js文件夹下


(3)完成JSP页面

Xml代码 复制代码
  1. <%@ page language="java" pageEncoding="GBK"%>  
  2. <%@ taglib prefix="s" uri="/struts-tags"%>  
  3. <html>  
  4.     <head>  
  5.         <title><s:text name="user.register" /></title>  
  6.         <!--导入JS内库-->        
  7.         <script src="js/prototype-1.4.0.js" type="text/javascript"></script>  
  8.         <script src="js/json.js" type="text/javascript"></script>  
  9.         <!--自定义Ajax事件-->     
  10.         <script language="JavaScript">  
  11.             function validateName()   
  12.             {   
  13.                 //请求的地址   
  14.                 var url = 'validateName.action';   
  15.                 var params = Form.Element.serialize('user.uid');   
  16.                 //创建Ajax.Request对象,对应于发送请求   
  17.                 var myAjax = new Ajax.Request(   
  18.                 url,   
  19.                 {   
  20.                     //请求方式:POST   
  21.                     method:'post',   
  22.                     //请求参数   
  23.                     parameters:params,   
  24.                     //指定回调函数   
  25.                     onComplete: processResponse,   
  26.                     //是否异步发送请求   
  27.                     asynchronous:true   
  28.                 });   
  29.             }   
  30.             function processResponse(request)   
  31.             {                  
  32.                 var action = request.responseText.parseJSON();   
  33.                 $("tip").innerHTML = action.tip;   
  34.                 $("tip2").innerHTML='欢迎您,'+action.user.uid;   
  35.             }      
  36.         </script>  
  37.     </head>  
  38.     <body>  
  39.     <span id="tip" style="color:red;font-weight:bold"></span>  
  40.         <s:form action="Register" validate="true">  
  41.             <s:textfield name="user.uid" key="user.uid" onblur="validateName();"/>  
  42.             <s:password name="user.upwd" key="user.upwd" />  
  43.             <s:submit key="submit" />  
  44.         </s:form>  
  45.     </body>  
  46. </html>  
<%@ page language="java" pageEncoding="GBK"%> <%@ taglib prefix="s" uri="/struts-tags"%> <html> <head> <title><s:text name="user.register" /></title> <!--导入JS内库--> <script src="js/prototype-1.4.0.js" type="text/javascript"></script> <script src="js/json.js" type="text/javascript"></script> <!--自定义Ajax事件--> <script language="JavaScript"> function validateName() { //请求的地址 var url = 'validateName.action'; var params = Form.Element.serialize('user.uid'); //创建Ajax.Request对象,对应于发送请求 var myAjax = new Ajax.Request( url, { //请求方式:POST method:'post', //请求参数 parameters:params, //指定回调函数 onComplete: processResponse, //是否异步发送请求 asynchronous:true }); } function processResponse(request) { var action = request.responseText.parseJSON(); $("tip").innerHTML = action.tip; $("tip2").innerHTML='欢迎您,'+action.user.uid; } </script> </head> <body> <span id="tip" style="color:red;font-weight:bold"> <s:form action="Register" validate="true"> <s:textfield name="user.uid" key="user.uid" οnblur="validateName();"/> <s:password name="user.upwd" key="user.upwd" /> <s:submit key="submit" /> </s:form> </body> </html>

 

(4)完成Action

代码略。

 

(5)配置Action

Xml代码 复制代码
  1. <package name="a" extends="json-default" namespace="">    
  2.  <action name="validateName" class="demo.ValidateName">  
  3.       <result type="json"/>  
  4. </action>   
<package name="a" extends="json-default" namespace=""> <action name="validateName" class="demo.ValidateName"> <result type="json"/> </action>

 

(6)总结

使用JSON插件开发Ajax非常方便

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值