JSON

struts2+spring+hibernate+json+jquery+flexigrid集成和在集成过程中需要注意的

字号+ 作者:H5之家 来源:H5之家 2015-11-21 16:42 我要评论( )

生成相应的get和set 方法 map.put(

生成相应的get和set 方法

map.put("id","1");//对应"id":"1","

map.put("cell",new Object{bean.getA(),bean.getB()......})//对应cell":["a","b","c","e"]

rows.add(map);//对应"rows":[
{"id":"1","cell":["a","b","c","e"]},
{"id":"2","cell":["a","b","c","e"]},
{"id":"3","cell":["a","b","c","e"]},
{"id":"4","cell":["a","b","c","e"]},
]}

  total="100""total":111, //数据总数
  pate="2"//"page":4, //页码(第几页)

这样就可以构造出正确的数据格式

当然,可能还有其它方法,本人出正在学习中,只是把我在学习过程中的一体会跟大家分享一下.

 

  

      好久都没有写博客了,这久公司正在做一个项目,原来是打算使用原来做OA系统时使用的框架的,但是又觉得个框架所使用的技术有点老了,想重新集成一个新框架,最后决定使用现在比较主流的技术,在视图层所使用的表格控件,本来是打算使用功能比较强大的dhtmlxgrid的,但是在这个表格控件的样式不好定义,使用默认的样式和我想要的UI样式不协调,最后决定使用jquery的一个插件表格flexigrid,在集成和使用的过程中遇到了一些问题,实在让我郁闷得很,但最终还是一一解决了.在些做一个小结.有不对的地方希望各位大虾不要拍砖.

     对于struts2和spring+hibernate的集成没什么好说的网上有好多这方面的资料,在些就不讲解了.只讲一下如何使用json传输数据.

     在stuts2中使用json传输数据,需要使用到一个struts2的插件jsonplugin,在网上下载后,直接考到类路径下面就可以了,需要在struts2的配置sturts.xml文件里中里修改一下如下:

  1,  <package extends="json-default" >//包要继承这个,因为jsonplugin自己带了一个配置文件struts-plugin.xml,里面继承了struts-default包,文件如下:

<?xml version="1.0" encoding="UTF-8" ?>

<!DOCTYPE struts PUBLIC
        "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
        "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>
    <package extends="struts-default">
        <result-types>
            <result-type/>
        </result-types>
        <interceptors>
            <interceptor/>
        </interceptors>
    </package>
</struts>
2, 修改action的返回值类型,当使用这个插件以后,可以不返回任何视图,直接返回json数据.交由js处理

    <action method="list" >
   <result  type="json"></result>
  </action>

后台基本配置好了,下面就是对前台的一个整合

下载jquery和flexigrid包含到页面,注意顺序,先jquery.js在flexigrid.js.

表格初如化

   1,定义表格容器,对flexigrid是需要有个表格容器才能显示的;

<table></table>

   2,初始化

   <script>

 $(document).ready(function(){
  $("#grid").flexigrid({
 url: "demo.action",
 dataType: 'json',
 colModel : [{display: '编号', name : 'id', width : 20, sortable : true, align: 'center'}, 
 {display: '姓名, name : 'name', width : 180, sortable : true, align: 'left'},
 {display: '生日', name : 'bathday', width : 60, sortable : true, align: 'left'},
 {display: '年龄, name : 'age', width : 60, sortable : true, align: 'left'}],
   sortname: "id",
    sortorder: "desc",
    usepager: true,
 title: '表头名称',
 useRp: false,
 rp: 10,
 showTableToggleBtn: true,
 procmsg: '正在加载数据,请稍等...'

   </script>

还有许多参数,具体作用如下:

下面就是最主要的一点,把返回的json格式的数据填到表格里

     后台业务代码我就不写了,这里主要讲一下返回的json格式,前几天就是因为返回的格式不对,表格里老是显示不出来数据,郁闷得很.

     flexigrid要求的返回格式,

{
"total":111, //数据总数
"page":4, //页码(第几页)

"rows":[
{"id":"1","cell":["a","b","c","e"]},
{"id":"2","cell":["a","b","c","e"]},
{"id":"3","cell":["a","b","c","e"]},
{"id":"4","cell":["a","b","c","e"]},
]}

格式一定要按照上面的来,要不然就是显示不出来,如果json格式是自己转换的话,但是不难,问题是,我们使用了插件,插件会自动帮我们转换,但是按照一般的来处理就会导致转换出来的格式不对,我在这里说一下.几种类型的转成json后的返回值:

map

{"map名":{}}转换时会自动在前面加上一个map后面才是值

{"map":{"id":2,"age":22,"name":"zhang","bathday":"2009-08-09"}}

list

{"list名":{}}同上

{"list":[{"age":12,"bathday":"2009-10-11","id":1,"name":"deng"},{"age":22,"bathday":"2009-08-09","id":2,"name":"zhang"}]}

javaBean

{"bean名":{}}同上

{"dean":{"age":12,"bathday":"2009-10-11","id":1,"name":"deng"}}

直接返变量

{"":"","":""}

{"age":22,"bathday":"2009-08-09","id":2,"name":"zhang"}

从上面几种返回格式,我们就可以去构造flexigrid所需要的数据格式了

{
"total":111, //数据总数
"page":4, //页码(第几页)

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • struts2+ajax+json action向页面返回int型数据,页面报异常org.a

    struts2+ajax+json action向页面返回int型数据,页面报异常org.a

    2016-01-31 15:35

  • AFN post JSON

    AFN post JSON

    2016-01-21 18:13

  • 6.Core Json – JSON和Ruby

    6.Core Json – JSON和Ruby

    2016-01-20 15:00

  • wordpress 4.4 禁用REST API/移除wp

    wordpress 4.4 禁用REST API/移除wp

    2016-01-18 18:10

网友点评