初析Struts2中的Ajax开发实例

  Web2.0的随波逐流,Ajax那是大放异彩,Struts2框架自己整合了对Ajax的原生支持(struts 2.1.7+,之前的版本可以通过插件实现),框架的整合只是使得JSON的创建变得异常简单,并且可以简单的融入到Struts2框架中,当然这只是在我们需要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.    
  2.    
  3.     "> 
  4.   获取 
  5.    
  6.    
  7.    
  8.   functionloadInfo() {  
  9.   $("#info").load("loadInfo");  
  10.   } 
  11.    
  12.    
  13.    
  14.   
 
  •    
  •    
  •   index.jsp包含一个按钮,点击按钮则会触发异步请求事件。

      struts.xml

     
     
     
     
    1.    
    2.    
    3.   /info.jsp 
    4.    
    5.    

      可见上面的异步请求的结果将会是加载info.jsp,info.jsp只是一个简单网页,不列出了。

      运行效果如下:

    单击获取之后:

    此时的页面源代码:

      

    标签中嵌套了标签,不符合规范,其实我们只要吧info.jsp写的没有<title>之类的标签,就不会出现这种情况了。</p><p>  以上说的异步请求仅适用于请求单个文件,如果我们请求的是动态数据,并且数据需要以JSON格式返回,上面的方法将会显得力不从心,这是struts2的原生支持就得出马了。</p><p>  使用struts2的ajax,必须在项目中引入struts2-json-plugin-2.2.1.jar,在版本2.1.7+都一句绑定在struts2发行包里面了(之前的版本可以在这下载)。记住,要引入struts2-json-plugin-2.2.1.jar。</p><p>  这次我们使用另一个例子,模拟加载评论:</p><p>  dto对象,Comment.java</p><pre> <ol> <li>packagecn.codeplus.po;  </li> <li>publicclassComment {  </li> <li>privatelongid;privateString nickname;</li> <li>privateString content;publiclonggetId() {returnid;  </li> <li>  }  </li> <li>publicvoidsetId(longid) {</li> <li>this.id =id;  </li> <li>  }  </li> <li>publicString getNickname() {returnnickname;  </li> <li>  }  </li> <li>publicvoidsetNickname(String nickname) {</li> <li>this.nickname =nickname;  </li> <li> }  </li> <li>publicString getContent() {returncontent;  </li> <li>  }  </li> <li>publicvoidsetContent(String content) {</li> <li>this.content =content;  </li> <li>  }  </li> <li>  } </li> </ol></pre><p>  新的InfoAction.java </p><pre> <ol> <li>packagecn.codeplus.action;  </li> <li>importjava.util.ArrayList;importjava.util.List;  </li> <li>importcn.codeplus.po.Comment;  </li> <li>importcom.opensymphony.xwork2.ActionSupport;  </li> <li>publicclassInfoAction extendsActionSupport {  </li> <li>privatestaticfinallongserialVersionUID =1359090410097337654L;  </li> <li>privateList<Comment>comments =newArrayList<Comment>();//没getter and setter方法的属性不会被串行化到JSON  </li> <li>  @SuppressWarnings("unused")  </li> <li>privateString title;//!!!使用transient修饰的属性也会被串行化到JSONprivatetransientString content;publicString loadInfo() {  </li> <li>  title="123木头人";  </li> <li>  content="你是木头人,哈哈。";  </li> <li>  loadComments();returnSUCCESS;  </li> <li>  }/*** 加载留言信息*/  </li> <li>  privatevoidloadComments() {  </li> <li>  Comment com1 =newComment();  </li> <li>  com1.setContent("很不错嘛");  </li> <li>  com1.setId(1);  </li> <li>  com1.setNickname("纳尼");  </li> <li>  Comment com2 =newComment();  </li> <li>  com2.setContent("哟西哟西");  </li> <li>  com2.setId(2);  </li> <li>  com2.setNickname("小强");  </li> <li>  comments.add(com1);  </li> <li>  comments.add(com2);  </li> <li>  }publicList<Comment>getComments() {returncomments;  </li> <li>  }publicvoidsetComments(List<Comment>comments) {this.comments =comments;  </li> <li>  }publicstaticlonggetSerialversionuid() {returnserialVersionUID;  </li> <li>  }publicString getContent() {returncontent;  </li> <li>  }publicvoidsetContent(String content) {this.content =content;  </li> <li>  }  </li> <li>  }  </li> <li>  index.jsp还是那个index.jsp。(*^__^*) 嘻嘻……  </li> <li>  struts.xml变化挺大:  </li> <li>  <package name="ajaxDemo"extends="json-default"> </li> <li>  <action name="loadInfo"class="cn.codeplus.action.InfoAction"method="loadInfo"> </li> <li>  <result name="success"type="json"></result> </li> <li>  </action> </li> <li>  </package> </li> </ol></pre><p>  在struts.xml中:</p><p>  首先,package extends由struts-default转变为json-default,这是必须的,只用在json-default中才包含下面使用的result type为 json。</p><p>  然后就是result类型需显示指明为json,result标签内,无需指明视图指向的界面。</p><p>  ***就是运行结果啦:</p><p>  点击“获取”按钮之后:</p></p><p>  可见comments对象和content对象都被串行化到JSON数据了,不知道是不是版本的问题,很多资料都说使用transient修饰的属性不会被串行化到JSON的。</p><p>  为了使content对象不被串行化到JSON,在不能舍弃其getter setter方法的时候,我们可以这样在content的getter方法上面加上注解:@JSON(serialize=false)</p><pre> <ol> <li>  ...  </li> <li>  @JSON(serialize=false)publicString getContent() {returncontent;  </li> <li>  }publicvoidsetContent(String content) {this.content =content;  </li> <li>  }  </li> <li>  ... </li> </ol></pre><p>  这时的结果如下:</p></p><p>  @JSON和json类型的result都还有很多可选项,无非就是串行化谁,不串行化谁,返回数据的MIME类型,读者可以自行参考相关文档。</p><p>  获取到JSON数据了,下一步就是在前台使用js处理JSON数据了,本人JS不精,喜欢使用jQuery解析,如有兴趣,且听下回分解jQuery解析JSON数据。</p> <p> 本文标题:<a href="http://www.csdahua.cn/qtweb/news20/537020.html">初析Struts2中的Ajax开发实例</a> <br> 分享网址:<a href="http://www.csdahua.cn/qtweb/news20/537020.html">http://www.csdahua.cn/qtweb/news20/537020.html</a> </p> <p> 网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等 </p> <p class="adpic"> <a href="https://www.cdcxhl.com/service/ad.html" target="_blank" class="ad">广告</a> <a href="" target="_blank" class="adimg"><img src=""></a> </p> <p class="copy"> 声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: <a href="http://www.csdahua.cn/" target="_blank">快上网</a> </p> </div> <div class="newsmorelb"> <p>成都快上网为您推荐相关内容</p> <ul> <li> <a href="/qtweb/news19/537019.html">Redis超强大的命令(redis超全指令)</a> </li><li> <a href="/qtweb/news18/537018.html">html如何设计表格样式</a> </li><li> <a href="/qtweb/news17/537017.html">为什么打游戏ping不稳</a> </li><li> <a href="/qtweb/news16/537016.html">云服务本地部署收费?(云服务和本地服务器的优势)</a> </li><li> <a href="/qtweb/news15/537015.html">如何发现Redis的热点数据(redis热点怎么发现)</a> </li><li> <a href="/qtweb/news14/537014.html">修改Linux用户名的正确姿势(Linux改用户名)</a> </li><li> <a href="/qtweb/news13/537013.html">了解如何使用Node.js构建微服务</a> </li><li> <a href="/qtweb/news12/537012.html">湖南科技大学研究生处被植入恶意代码</a> </li><li> <a href="/qtweb/news11/537011.html">实时掌控Linux服务器状态监控神器(linux服务器状态监控)</a> </li> </ul> </div> </div> <div class="col-lg-3 noneb"> <div class="bkright" style="margin-top: 0"> <p><a href="https://www.cdcxhl.com/news/appsheji/">App设计知识</a></p> <ul> <li> <a class="text_overflow" href="/qtweb/news45/194345.html">美国针对黑人解放组织的网络攻击暴增!</a> </li><li> <a class="text_overflow" href="/qtweb/news48/190798.html">选择香港机房该从哪些方面入手</a> </li><li> <a class="text_overflow" href="/qtweb/news36/178886.html">域名反查ip方法?(域名如何查ip)</a> </li><li> <a class="text_overflow" href="/qtweb/news0/373400.html">Web应用极大提升Web性能的基于Redis缓存的应用(基于redis缓存的)</a> </li><li> <a class="text_overflow" href="/qtweb/news35/464935.html">万科万物云公司怎么样?(好的云服务器提供商)</a> </li><li> <a class="text_overflow" href="/qtweb/news19/342869.html">湖南航信云服务平台需要缴费吗?服务好又优惠的云计算平台</a> </li><li> <a class="text_overflow" href="/qtweb/news24/284424.html">如何查看Linux下MySQL的缓存?(linuxmysql查看缓存)</a> </li><li> <a class="text_overflow" href="/qtweb/news36/509636.html">Redis配置指南从零开始(redis的配置说明)</a> </li><li> <a class="text_overflow" href="/qtweb/news26/85076.html">如何购买新虚拟主机(如何购买新虚拟主机教程)</a> </li><li> <a class="text_overflow" href="/qtweb/news16/451416.html">音箱怎么拆?(音箱怎么拆开图解)</a> </li><li> <a class="text_overflow" href="/qtweb/news14/472014.html">何为息壤主机,了解息壤主机的特点与优势</a> </li><li> <a class="text_overflow" href="/qtweb/news43/472443.html">云平台的优点和缺点?云服务器优缺点</a> </li><li> <a class="text_overflow" href="/qtweb/news47/304747.html">在ASP.NETMVC中实现大文件异步上传</a> </li><li> <a class="text_overflow" href="/qtweb/news42/521942.html">抖音消息撤回失败是为什么</a> </li><li> <a class="text_overflow" href="/qtweb/news23/426973.html">红色闪电探究跳表的时间复杂度(redis跳表时间复杂度)</a> </li> </ul> </div> <div class="bkright tag"> <p><a href="https://www.cdcxhl.com/hangye/" target="_blank">行业网站建设</a></p> <ul> <li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/shipindai/" target="_blank">食品包装袋</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/jiagu/" target="_blank">加固</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/sdjbc/" target="_blank">隧道混凝土搅拌车</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/zkj/" target="_blank">公路钻孔机</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/mutuopan/" target="_blank">木托盘</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/menchuang/" target="_blank">门窗定制</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/blgzd/" target="_blank">玻璃钢坐凳</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/chunshuiji/" target="_blank">纯水机</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/xiaoguotu/" target="_blank">效果图设计</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/shayanfudiao/" target="_blank">砂岩浮雕</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/shiliangting/" target="_blank">石凉亭</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/ggzz/" target="_blank">广告制作</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/kafeitingsj/" target="_blank">咖啡厅设计</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/swzbw/" target="_blank">三维植被网</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/zufadianji/" target="_blank">发电机租赁</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/blgds/" target="_blank">玻璃钢雕塑</a> </li> </ul> </div> </div> </div> <div class="carousel-inner linkbg" style="background: #fff"> <div class="container"> <a href="http://www.cdxwcx.cn/tuoguan/meishan.html" target="_blank">眉山主机托管</a>    <a href="https://www.cdcxhl.com/xiaochengx.html" target="_blank">成都小程序开发</a>    <a href="http://www.ybzwz.com/" target="_blank">宜宾网站设计</a>    <a href="http://www.cxjianzhan.cn/fwxm/pinpai.html" target="_blank">成都品牌网站设计</a>    <a href="http://www.biboxcn.com/" target="_blank">乐山装修公司</a>    <a href="http://www.hdybtv.com/" target="_blank">造型师设计</a>    <a href="http://www.cxhlcq.cn/" target="_blank">创新互联重庆</a>    <a href="http://www.sffdjwx.com/" target="_blank">沃尔沃电机组维修保养</a>    <a href="http://www.ybwzjz.com/" target="_blank">宜宾做网站</a>    <a href="http://www.cdkjz.cn/wangzhan/yunying/" target="_blank">成都网站代运营</a>    <a href="https://www.cdcxhl.cn/ " target="_blank">php空间</a>    <a href="https://www.cdcxhl.com/waimao.html" target="_blank">外贸网站建设</a>    <a href="https://www.cdcxhl.com/cqtuoguan.html" target="_blank">重庆主机托管</a>    <a href="https://www.cdxwcx.com/city/guanghan/" target="_blank">广汉做网站</a>    <a href="http://www.cdiso.cn/" target="_blank">小谭建站</a>    <a href="http://chengdu.cdcxhl.cn/jianshe/ " target="_blank">成都网站建设公司</a>    <a href="http://www.scluxian.com/" target="_blank">泸县网站建设</a>    <a href="https://www.cdcxhl.com/weihu/chengdu.html" target="_blank">成都网站维护公司</a>    <a href="http://seo.cdkjz.cn/" target="_blank">网络推广外包</a>    <a href="http://www.pcbaojie.cn/" target="_blank">平昌保洁</a>     </div> </div> <footer> <div class="carousel-inner footjz"> <div class="container"> <i class="icon iconfont zbw"></i> 高品质定制 <i class="icon iconfont"></i> 跨终端自动兼容 <i class="icon iconfont"></i> 节约开发成本 <i class="icon iconfont"></i> 开发周期短 <i class="icon iconfont"></i> 一体化服务 <button type="button" class="btn btn-default btn-lg" onClick="window.location.href='tencent://message/?uin=631063699&Site=&Menu=yes'"> 立即开始2800定制网站建设</button> <button type="button" class="btn btn-default btn-xs" onClick="window.location.href='tencent://message/?uin=631063699&Site=&Menu=yes'"> 2800定制网站建设</button> </div> </div> <div class="carousel-inner bqsy"> <div class="container"> <div class="lxfs"> <h4 class="yutelnone">028-86922220 13518219792</h4> <h4 class="yutelblock"><a href="tel:02886922220">028-86922220</a> <a href="tel:13518219792">13518219792</a></h4> <a class="btn btn-default" href="tencent://message/?uin=532337155&Site=&Menu=yes" role="button">网站建设<span>QQ</span>:532337155</a> <a class="btn btn-default" href="tencent://message/?uin=631063699&Site=&Menu=yes" role="button">营销推广<span>QQ</span>:631063699</a> <a class="btn btn1 btn-default" href="mqqwpa://im/chat?chat_type=wpa&uin=532337155&version=1&src_type=web&web_src=oicqzone.com" role="button">网站制作<span>QQ</span>:532337155</a> <a class="btn btn1 btn-default" href="mqqwpa://im/chat?chat_type=wpa&uin=631063699&version=1&src_type=web&web_src=oicqzone.com" role="button">营销推广<span>QQ</span>:631063699</a> <a class="btn btn-default nonea" href="tencent://message/?uin=1683211881&Site=&Menu=yes" role="button">售后QQ:1683211881</a> <div class="dz">成都快上网专注: <a href="http://www.csdahua.cn/" target="_blank">网站优化</a> <a href="http://www.csdahua.cn/" target="_blank">网络推广</a> <a href="http://www.csdahua.cn/" target="_blank">网站建设</a> <address>地址:成都太升南路288号锦天国际A幢10楼</address> </div> </div> <div class="bzdh dz"><img src="https://www.cdcxhl.com/imges/bottom_logo.png" alt="创新互联"> <p><a href="https://www.cdcxhl.com/menu.html" target="_blank">成都创新互联科技有限公司</a><br> Tel:028-86922220(7x24h)</p></div> </div> </div> </footer> </body> </html> <script> $.getJSON ("../../qtwebpic.txt", function (data) { var jsonContent = { "featured":data } var random = jsonContent.featured[Math.floor(Math.random() * jsonContent.featured.length)]; $(".adpic .adimg").attr("href",random.link) $(".adpic img").attr("src",random.pic); }) </script>