struts2.1.8 、json插件和jquery整合

3 篇文章 0 订阅

struts2.1.8 、json插件和jquery整合

 

1、必须的jar包

struts2-json-plugin-2.1.8

json-lib-2.3-jdk15

ezmorph-1.0.6

jakarta commons-lang 2.4

jakarta commons-beanutils 1.7.0

jakarta commons-collections 3.2

jakarta commons-logging 1.1.1

2、struts.xml配置

a、直接继承json-default包

<package name="default-package" abstract="true" extends="json-default">

<!-- 中间定义其他元素 -->

</package>

b、添加以下元素到struts.xml文件中(其实下面的xml代码也就是struts2-json-plugin-2.1.8包中struts-plugin.xml的内容

这里只是把它提出来放到struts.xml文件中,避免继承包)

<result-types>

            <result-type name="json" class="org.apache.struts2.json.JSONResult"/>

        </result-types>

        <interceptors>

            <interceptor name="json" class="org.apache.struts2.json.JSONInterceptor"/>

        </interceptors>

3、action配置 注意下面的result类型type 以及参数root,田type指定结果类型为json

而参数root用来指明将action中的哪个参数作为json串返回给客户端

<package name="func" namespace="/func" extends="default-package">

<action name="getFuncInfoByAjax" class="funcAction" method="getFuncInfoByAjax">

<result name="success" type="json">

<param name="root">jsonFuncInfo</param>

</result>

</action>

</package>

4、action代码:

 

public String getFuncInfoByAjax(){ func = getFuncService().findById(getFuncId()); FuncInfo funcInfo = new FuncInfo(); funcInfo.setId(func.getId()); funcInfo.setName(func.getName()); if( func.getFunc() != null){ funcInfo.setParentId(func.getFunc().getId()); funcInfo.setParentName(func.getFunc().getName()); } funcInfo.setMenuType(func.getMenuType()); funcInfo.setType(func.getType()); funcInfo.setUrl(func.getUrl()); funcInfo.setRemark(func.getRemark()); JSONObject jsonObject = JSONObject.fromObject(funcInfo); jsonFuncInfo = jsonObject.toString() ; return SUCCESS ;} 

 

5、jsp页面代码:

<script type="text/javascript" src="<%=request.getContextPath()%>/js/jquery/jquery-1.4.2.min.js"></script>

function fillFuncInfo(){ var funcId = tree.getSelectedItemId(); //alert(funcId); var url = "<%=request.getContextPath()%>/func/getFuncInfoByAjax.action"; $.getJSON(url,{funcId:funcId,ran:Math.random()},function(json){ if(json.length > 0){ var jsonFuncInfo = eval("("+json+")"); $("#funcName").html(jsonFuncInfo.name); $("#funcParentName").html(jsonFuncInfo.parentName); if( jsonFuncInfo.type == "F" ){ $("#funcType").html("目录"); } else if( jsonFuncInfo.type == "F" ){ $("#funcType").html("链接"); $("#funcUrl").html(jsonFuncInfo.url); } if(jsonFuncInfo.menuType == "Y" ){ $("#funcMenuType").html("菜单项"); } else { $("#funcMenuType").html("页面链接"); } $("#funcRemark").html(jsonFuncInfo.remark); } }); }

 

6、测试,OK!

需要注意的地方 使JSONObject转换的时候,被转换的对象中不能出现引用自身的属性,或者说不能出现循环引用,

这样转换不会有任何结果,貌似也不报错!

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值