自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

初析Struts2中的Ajax開發(fā)實例

開發(fā) 后端
Ajax作為WEB開發(fā)中的明星,自有其性能和開發(fā)上的優(yōu)勢。本文將給大家簡單介紹Struts2中的Ajax開發(fā)實例,希望對大家有所幫助。

  Web2.0的隨波逐流,Ajax那是大放異彩,Struts2框架自己整合了對Ajax的原生支持(struts 2.1.7+,之前的版本可以通過插件實現(xiàn)),框架的整合只是使得JSON的創(chuàng)建變得異常簡單,并且可以簡單的融入到Struts2框架中,當(dāng)然這只是在我們需要JSON的時候才會顯得流光溢彩。

  首先不談Struts2的原生支持,我們自己寫一個ajax示例,使用異步請求,直接請求action動作:

  InfoAction.java

  1. packagecn.codeplus.action;importcom.opensymphony.xwork2.ActionSupport;  
  2. publicclassInfoAction extendsActionSupport {
  3. privatestaticfinallongserialVersionUID =1359090410097337654L;  
  4. publicString loadInfo() {returnSUCCESS;  
  5.   }  
  6.   } 

InfoAction僅僅是簡單的返回"success"。

  index.jsp

  1.   <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 
  2.   <html> 
  3.   <head>  <base href="<%=basePath%>"> 
  4.   <title>獲取</title> 
  5.   <script type="text/javascript"src="js/jquery.js"> 
  6.   </script> 
  7.   <script type="text/javascript"> 
  8.   functionloadInfo() {  
  9.   $("#info").load("loadInfo");  
  10.   }</script> 
  11.   </head> 
  12.   <body> 
  13.   <input type="button"value="獲取"id="btnGet"onclick="loadInfo()"/> 
  14.   <div id="info"></div> 
  15.   </body> 
  16.   </html> 

  index.jsp包含一個按鈕,點擊按鈕則會觸發(fā)異步請求事件。

  struts.xml

  1.   <package name="ajaxDemo"extends="struts-default"> 
  2.   <action name="loadInfo"class="cn.codeplus.action.InfoAction"method="loadInfo"> 
  3.   <result name="success">/info.jsp</result> 
  4.   </action> 
  5.   </package> 

  可見上面的異步請求的結(jié)果將會是加載info.jsp,info.jsp只是一個簡單網(wǎng)頁,不列出了。

  運行效果如下:

單擊獲取之后:

此時的頁面源代碼:

  <div>標(biāo)簽中嵌套了<title>標(biāo)簽,不符合規(guī)范,其實我們只要吧info.jsp寫的沒有<title>之類的標(biāo)簽,就不會出現(xiàn)這種情況了。

  以上說的異步請求僅適用于請求單個文件,如果我們請求的是動態(tài)數(shù)據(jù),并且數(shù)據(jù)需要以JSON格式返回,上面的方法將會顯得力不從心,這是struts2的原生支持就得出馬了。

  使用struts2的ajax,必須在項目中引入struts2-json-plugin-2.2.1.jar,在版本2.1.7+都一句綁定在struts2發(fā)行包里面了(之前的版本可以在這下載)。記住,要引入struts2-json-plugin-2.2.1.jar。

  這次我們使用另一個例子,模擬加載評論:

  dto對象,Comment.java

  1. packagecn.codeplus.po;  
  2. publicclassComment {  
  3. privatelongid;privateString nickname;
  4. privateString content;publiclonggetId() {returnid;  
  5.   }  
  6. publicvoidsetId(longid) {
  7. this.id =id;  
  8.   }  
  9. publicString getNickname() {returnnickname;  
  10.   }  
  11. publicvoidsetNickname(String nickname) {
  12. this.nickname =nickname;  
  13.  }  
  14. publicString getContent() {returncontent;  
  15.   }  
  16. publicvoidsetContent(String content) {
  17. this.content =content;  
  18.   }  
  19.   } 

  新的InfoAction.java 

  1. packagecn.codeplus.action;  
  2. importjava.util.ArrayList;importjava.util.List;  
  3. importcn.codeplus.po.Comment;  
  4. importcom.opensymphony.xwork2.ActionSupport;  
  5. publicclassInfoAction extendsActionSupport {  
  6. privatestaticfinallongserialVersionUID =1359090410097337654L;  
  7. privateList<Comment>comments =newArrayList<Comment>();//沒getter and setter方法的屬性不會被串行化到JSON  
  8.   @SuppressWarnings("unused")  
  9. privateString title;//!??!使用transient修飾的屬性也會被串行化到JSONprivatetransientString content;publicString loadInfo() {  
  10.   title="123木頭人";  
  11.   content="你是木頭人,哈哈。";  
  12.   loadComments();returnSUCCESS;  
  13.   }/*** 加載留言信息*/  
  14.   privatevoidloadComments() {  
  15.   Comment com1 =newComment();  
  16.   com1.setContent("很不錯嘛");  
  17.   com1.setId(1);  
  18.   com1.setNickname("納尼");  
  19.   Comment com2 =newComment();  
  20.   com2.setContent("喲西喲西");  
  21.   com2.setId(2);  
  22.   com2.setNickname("小強");  
  23.   comments.add(com1);  
  24.   comments.add(com2);  
  25.   }publicList<Comment>getComments() {returncomments;  
  26.   }publicvoidsetComments(List<Comment>comments) {this.comments =comments;  
  27.   }publicstaticlonggetSerialversionuid() {returnserialVersionUID;  
  28.   }publicString getContent() {returncontent;  
  29.   }publicvoidsetContent(String content) {this.content =content;  
  30.   }  
  31.   }  
  32.   index.jsp還是那個index.jsp。(*^__^*) 嘻嘻……  
  33.   struts.xml變化挺大:  
  34.   <package name="ajaxDemo"extends="json-default"> 
  35.   <action name="loadInfo"class="cn.codeplus.action.InfoAction"method="loadInfo"> 
  36.   <result name="success"type="json"></result> 
  37.   </action> 
  38.   </package> 

  在struts.xml中:

  首先,package extends由struts-default轉(zhuǎn)變?yōu)閖son-default,這是必須的,只用在json-default中才包含下面使用的result type為 json。

  然后就是result類型需顯示指明為json,result標(biāo)簽內(nèi),無需指明視圖指向的界面。

  ***就是運行結(jié)果啦:

  點擊“獲取”按鈕之后:

  可見comments對象和content對象都被串行化到JSON數(shù)據(jù)了,不知道是不是版本的問題,很多資料都說使用transient修飾的屬性不會被串行化到JSON的。

  為了使content對象不被串行化到JSON,在不能舍棄其getter setter方法的時候,我們可以這樣在content的getter方法上面加上注解:@JSON(serialize=false)

  1.   ...  
  2.   @JSON(serialize=false)publicString getContent() {returncontent;  
  3.   }publicvoidsetContent(String content) {this.content =content;  
  4.   }  
  5.   ... 

  這時的結(jié)果如下:

  @JSON和json類型的result都還有很多可選項,無非就是串行化誰,不串行化誰,返回數(shù)據(jù)的MIME類型,讀者可以自行參考相關(guān)文檔。

  獲取到JSON數(shù)據(jù)了,下一步就是在前臺使用js處理JSON數(shù)據(jù)了,本人JS不精,喜歡使用jQuery解析,如有興趣,且聽下回分解jQuery解析JSON數(shù)據(jù)。

原文鏈接:http://www.cnblogs.com/codeplus/archive/2011/07/18/2109316.html

【編輯推薦】

  1. 理解JSON:3分鐘課程輕松搞定
  2. JSONP跨域原理和jQuery.getJSON用法
  3. 在PHP語言中使用JSON
  4. Jackson框架輕易轉(zhuǎn)換JSON
  5. Ajax和WEB服務(wù)數(shù)據(jù)格式:JSON JSONP
責(zé)任編輯:彭凡 來源: 博客園
相關(guān)推薦

2011-07-19 09:08:38

jQuery

2011-05-13 09:53:02

strutsAjax

2009-07-17 17:45:56

iBATIS Spri

2009-07-29 09:54:34

struts2和str

2017-07-11 09:42:22

漏洞

2009-06-05 10:43:29

struts2 checheckbox實例

2009-06-25 15:11:28

Struts2教程Struts2程序

2009-06-08 16:44:00

2009-02-04 10:51:07

2009-06-04 09:20:19

struts2 if標(biāo)使用

2009-07-14 17:10:44

struts2webwork

2012-05-10 14:00:06

StrutsjsonJava

2009-06-01 15:44:18

2009-07-03 09:35:57

Struts2 JSP

2016-04-29 10:58:13

2009-06-04 08:34:24

Struts2配置struts.xml

2009-06-18 11:37:24

Struts2中ForJavaScript

2009-06-05 10:05:50

struts menustruts2

2011-04-28 09:52:04

Struts2

2010-05-10 15:06:37

Oracle stru
點贊
收藏

51CTO技術(shù)棧公眾號