JQUERY+JSON+Struts 1.3例子

原文地址:http://bryanlin.x10hosting.com/2010/07/jqueryjsonstruts-1-3/

 

      最近在做个项目,要求前端用Jquery和jsp,后端用struts+spring+ibatis,由于以前一般用XML做前后台的数据传输,最近学习Jquery时发现JSON比XML更方便处理,于是决定用Jquery通过Ajax与后台通讯,数据格式采用Json来做。

      方案确定了,开始找资料,谁知大多数例子都是在客户端将form序列化,传输到服务端,然后服务端通过request.getParameter()一个字段一个字段的拿出来处理,最后返回Json格式的数据给客户端,客户端再处理。

      这样获取参数也太麻烦了,还不如直接用struts form呢,但是那样要建很多formbean,不爽。有没有更好的办法呢?比如一次request.getParameter()就把所有Json数据获取到,获取到后,接下来就好办了,通过JSONObject.fromObject()方法,很容易就可以将Json数据转换成JSONObject对象了,再通过JSONObject.toBean( )转换成DTO,多方便啊。

      找来找去,还真找到办法了,就是在客户端动手脚:

 

1. 不要用序列化,而是手工将所有要传到服务端的数据拼成Json对象,格式为:{key1:value1,key2:value2 ……},方法如下:

 

2. 通过JSON.stringify(),将拼成的Json对象字符串化,打印出来,就是上面那样子,只不过对象alert出来显示object,字符串alert出来是上面那格式。

 

3. 将第2步生成的字符串作为value,再拼一个Json对象,key自己起名,比如json。

 

4. 把第三步生成的Json对象作为参数,通过Jquery的$.post()之类的方法发送到服务端。

 

然后在服务端,如下处理:

 

其中XXDTO是你的DTO,是不是简单多了?

服务端处理完毕,组装Json格式数据,应答客户端,比如:

 

最后,如果Ajax请求成功,$.post中定义的回调函数将执行,该函数先是显示服务端返回信息,然后如果返回成功信息的话,则清空页面输入框。

怎么样?比直接用Json序列化和Struts简单吧?

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值