`

整合struts2,jquery,json。采用jquery ajax,从struts2 action返回json类型数据(转)

    博客分类:
  • S2SH
阅读更多

本文开发环境是SSH2,ajax插件使用jQuery 1.2.6.js和json2.js

实现目的:

在struts2 标签s:doubleselect二级联动标签的基础上实现事件:第二级onchange时调用struts2 action,在action中查询一个名称,然后返回回来,此信息显示在页面上(这只是给用户一个提示信息,不影响表单能否提交)

由于struts2 doubleselect标签任何事件都不起作用,只能根据查看源文件中生成的id来定义它的onchange事件

 jsp页面引入了jquery.js和json2.js

需要加事件的二级联动jsp代码

 

  1. <td class="alignLeft" width="22%">  
  2.         所属业务/项目名称:  
  3.     </td>  
  4.     <td valign="top" class="alignLeft" width="20%">  
  5.         <s:doubleselect name="changeApplyFormBO.operationId" list="operationList" listKey="id"  
  6.         listValue="operationName" doubleList="operationSubProductList"   
  7.         doubleListKey="id" doubleListValue="prudName"  doubleName="changeApplyFormBO.productId"  
  8.         headerKey=""  headerValue="--- Please Select ---" />    
  9.     <span id="company" style="color:red"></span>  
  10.     </td>  

 

我们需要在“项目名称”被改变的事件下调用函数,在生成的静态页面中查得它的id是cbApplySubmit_changeApplyFormBO_productId

说明一下,这里生成的id有一点规律,貌似。cbApplySubmit是本页面form表单的action,而changeApplyFormBO.productId是“项目名称”的name

下面给出定制下拉菜单事件的js

 

  1. <script>  
  2.       
  3.       $(function(){  
  4.           var obj=document.getElementById("cbApplySubmit_changeApplyFormBO_productId");  
  5.           obj.onchange=function(){      
  6.            var prodId=obj.value;  
  7.            var url="${contextPath}/assets/businessChange/ajaxGetCompany.do";  
  8.            var jsonProd={productId:prodId};    //JSON对象      
  9.            var prodStr=JSON.stringify(jsonProd);    //将JSON对象转变成JSON格式的字符串  
  10.            $.post(url,{json:prodStr},callback,"json");   
  11.           }  
  12.         function callback(json){     
  13.             $("#company").html(json.msg);  
  14.          }   
  15.      });   
  16.       
  17. </script>  

 

这里,不管是从浏览器端(JS,Ajax,Jquery等)发送给服务器端,还是从服务器端(Struts的Action,Servlet等)发送回客户端,发送的都是JSON格式的字符串

 

  1. var jsonProd={productId:prodId};  

 

这句是组装JSON对象,这里很简单,key是productId,value是页面选择的项目名称的id

 

  1. //将JSON对象转变成JSON格式的字符串  
  2. var prodStr=JSON.stringify(jsonProd);   

 

通过JavaScript内置对象JSON的stringify方法,将JSON对象转换成字符串。因为,我们传送给服务器端的要是JSON格式的字符串。

 

  1. $.post(url,{json:prodStr},callback,"json");   

 

这一句,jquery用POST方法向服务器端发送数据,url是我们要调用的action全路径,而{json:prodStr}是我们要发送的数据(data),{json:prodStr},其实也是一个JSON对象,Key:value的形式,注意,我们把prodStr这个json串发过去,在Action那里接收时,要接收“json”这个变量,这个变量的值就是我们发送的prodStr字符串。

回调函数(callback)是指服务器端成功返回时,在JS端执行的函数。最后一个参数“json”是返回数据类型的一种,另外,还有”text”、“xml”等

 

  1. function callback(json){     
  2.         $("#company").html(json.msg);  
  3.      }   
  4.  });  

 

company是span的id,请看最上面二级联动标签处。这个函数用来显示action中组装的json对象的value值

struts2 action类

 

  1. import org.json.JSONObject;  
  2.   
  3. public class CBApplyAction extends ActionSupport {  
  4.     private IProductMng productMng;  
  5.     private String json;  
  6.     /** 
  7.      * 通过选择的项目名称,给出提示事业部名称的提示信息 
  8.      *  
  9.      * @return 
  10.      * @throws Exception 
  11.      */  
  12.     public void ajaxGetCompany() throws Exception {  
  13.         JSONObject jsonObj = new JSONObject(json); // 将JSON格式的字符串构造成JSON对象  
  14.           
  15.         String productId = jsonObj.getString("productId"); // 获取JSON对象中的productId属性的值  
  16.           
  17.         ProductBO prod = productMng.loadProduct(Integer.parseInt(productId));  
  18.         Integer companyId = prod.getCompanyId();  
  19.         CompanyBO comp = productMng.loadCompany(companyId);  
  20.         String companyName = "事业部为:" + comp.getName();  
  21.         json = "{msg:'" + companyName + "'}";    //构造JSON格式的字符串     
  22.         sendMsg(json);    //发送JSON格式的字符串回JS端      
  23.     }  
  24.       
  25.     public void sendMsg(String content) throws IOException{      
  26.         HttpServletResponse response = ServletActionContext.getResponse();      
  27.         response.setCharacterEncoding("UTF-8");      
  28.         response.getWriter().write(content);      
  29.     }    
  30.   
  31.     public String getJson() {  
  32.         return json;  
  33.     }  
  34.   
  35.     public void setJson(String json) {  
  36.         this.json = json;  
  37.     }  
  38.   
  39.     public void setProductMng(IProductMng productMng) {  
  40.         this.productMng = productMng;  
  41.     }    
  42. }  
  

 

JSONObject是我从json的网站http://www.json.org/java/index.html上下载了一些java文件,然后将这些.java文件打成一个jar包json.jar,放在项目lib里面

ajaxGetCompany方法没有像struts2 别的方法那样有返回值String,这里设的是void,因我们不需要任何跳转

这里有个需要注意的,json = "{msg:'" + companyName + "'}"; companyName外面应该有引号括起来

struts2 配置文件

 

  1. <action name="ajaxGetCompany" class="CBApplyAction"  
  2.     method="ajaxGetCompany">  
  3. </action>  

 

没有result

分享到:
评论

相关推荐

    struts2+json+jquery实现ajax数据的存取

    "Struts2+JSON+jQuery实现Ajax数据的存取"就是一个典型的示例,它结合了强大的MVC框架Struts2、轻量级的数据交换格式JSON以及高效的前端库jQuery,以实现网页上的无刷新数据交互。下面将详细介绍这三个技术及其在...

    Struts2 ajax json使用介绍

    在后端,我们需要创建一个Struts2 Action类,用于处理Ajax请求并返回JSON数据。例如,创建一个名为`AjaxAction.java`的类: ```java import com.opensymphony.xwork2.ActionSupport; import org.apache.struts2....

    json2+jsonplugin struts2整合ajax时,使用json时需要的jar包

    在Struts2与Ajax的交互中,后端返回的JSON数据需要在前端被`json2.js`解析成可操作的对象,这样才能在页面上动态更新内容。 接下来,我们讨论Struts2的`jsonplugin`。Struts2 JSON插件是官方提供的一个扩展,它使...

    Jquery struts2 json 实现ajax

    标题 "Jquery struts2 json 实现ajax" 涉及到的是在Web开发中使用jQuery库与Struts2框架结合处理JSON数据的Ajax技术。这个主题主要关注如何通过前端的jQuery实现异步请求,与后端的Struts2框架进行交互,从而更新...

    Struts2JQueryJson

    Struts2JQueryJson是一个基于Struts2框架与jQuery库,结合JSON(JavaScript Object Notation)数据格式,实现Ajax异步加载对象数据的技术方案。在Web应用开发中,这种技术可以提升用户体验,因为它允许页面部分内容...

    Struts2 与Jquery Ajax的json数据交换的典型范例

    总结,Struts2和jQuery的Ajax JSON数据交换涉及以下几个关键步骤:配置Struts2的JSON插件,编写返回JSON数据的Action,使用jQuery发起Ajax请求并处理返回的JSON数据。通过这种方式,可以实现客户端与服务器之间的...

    struts2返回JSON数据的两种方式

    在本文中,我们将探讨两种在Struts2框架中返回JSON数据的方法。JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,广泛用于前后端交互,尤其是在AJAX请求中。Struts2提供了一套方便的机制来支持JSON...

    Struts2 + jQuery+JSON 实现ajax

    ### Struts2 + jQuery + JSON 实现Ajax 在现代Web开发中,Ajax技术因其能够实现网页的局部刷新而被广泛采用。本篇文章介绍如何利用Struts2框架结合jQuery与JSON来构建一个简单的Ajax功能。 #### 一、环境搭建 1. ...

    struts2+jquery执行ajax并返回json类型数据(源码)

    在这个"struts2+jquery执行ajax并返回json类型数据"的示例中,我们将探讨如何通过Ajax技术在后台Struts2框架与前端jQuery库之间交换JSON格式的数据。 首先,Struts2是一个强大的MVC(Model-View-Controller)框架,...

    jquery的ajax传json对象数组到struts2的action

    本文将深入探讨如何使用jQuery的AJAX方法发送JSON对象数组到Struts2的Action,并在后端进行处理。 首先,我们了解JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于...

    jquery ajax json struts2最简单例子测试成功

    2. **JSON与Struts2的结合**:Struts2 Action执行后返回一个JSON字符串,这个字符串被jQuery AJAX请求接收。通过Struts2的插件,如struts2-json-plugin,可以在Action类中直接返回一个包含JSON数据的对象,Struts2会...

    struts2+jquery+json+ajax例子

    在Struts2中,可以通过配置Action类的返回类型为"json",使得Action执行后返回JSON对象。JSON数据在Ajax请求和响应中起到关键作用,它可以将登录验证的结果(例如,成功或失败信息、错误消息等)以结构化的方式传递...

    struts2+json

    当Action执行完毕后,可以返回一个JSON结果类型,Struts2会自动将Action的属性转换为JSON格式并返回给前端。 接着,我们讨论AJAX。AJAX是一种在不重新加载整个网页的情况下,能够更新部分网页的技术。在本资源中,...

    struts2与json整合

    这样,Struts2就能够识别`json`类型的结果,并使用`JSONResult`来将Action返回的数据转换成JSON格式。 #### 3. 定义Action方法 在Struts2中,Action类中的方法负责处理来自客户端的请求。为了返回JSON数据,可以...

    struts2+json+ajax整合例子(导入即可运行,附带详细教程)

    Struts2、JSON和AJAX是Web开发中的关键技术,它们的整合可以实现高效的数据交互和动态页面更新。本文将深入探讨这些技术以及如何在实际项目中整合它们。 **Struts2** 是一个基于MVC(Model-View-Controller)设计...

    struts2 jquery json ajax 三级联动菜单

    比如,当用户在第一级菜单中做出选择后,通过Ajax调用Struts2的Action,Action返回JSON格式的数据,这些数据随后被jQuery解析并用来填充第二级菜单。 JSON(JavaScript Object Notation)是一种轻量级的数据交换...

    Struts2+Jquery+Ajax

    在Struts2框架下,我们可以使用Jquery的Ajax方法向服务器发送请求,获取JSON或XML数据,然后动态更新页面的部分内容。 在"06-mvc之struts2.ppt"中,可能涵盖了以下内容: 1. Struts2框架的基本概念和架构 2. 如何...

    Struts2 JQueryJson例子 .rar

    这个"Struts2 JQueryJson例子 .rar"压缩包很可能是包含了一个实际的项目实例,演示了如何在Struts2框架中利用JQuery和JSON进行数据交互。下面将详细讲解Struts2、JQuery和JSON的相关知识点: 1. **Struts2框架**: ...

    AJAX和struts2传递JSON数组

    在本场景中,我们将探讨如何使用AJAX来传递JSON数组,并在Struts2的Action中接收和处理这些数据。 首先,JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它易于人阅读和编写,同时也易于机器解析...

Global site tag (gtag.js) - Google Analytics