easyui datagrid queryParams

转自:http://www.cnblogs.com/zgqys1980/archive/2011/01/04/1925775.html

加载相关js和css,因为easyui依赖jquery,所有加载easyui前要先加载jquery,否则为提示找不到datagrid

 

 

  1. <!-- 加载jquery -->  
  2.         <script type="text/javascript" src="plugins/jquery/jquery-1.4.2.min.js"></script>  
  3.         <!-- 加载jquery-easyui -->  
  4.         <link rel="stylesheet" type="text/css" href="plugins/jquery/jquery-easyui-1.1.2/themes/default/easyui.css">  
  5.         <link rel="stylesheet" type="text/css" href="plugins/jquery/jquery-easyui-1.1.2/themes/icon.css">  
  6.         <script type="text/javascript" src="plugins/jquery/jquery-easyui-1.1.2/jquery.easyui.min.js"></script>  

 

界面加入

 

 

  1. <table id="cxdm"></table>  

 

加载datagrid的js代码

 

 

  1. //页面加载  
  2. $(document).ready(function(){  
  3.             loadGrid();  
  4. });  
  5.   
  6. //加载表格datagrid  
  7. function loadGrid()  
  8. {  
  9.     //加载数据  
  10.     $('#cxdm').datagrid({  
  11.                 width: 'auto',  
  12.                 height:300,               
  13.                 striped: true,  
  14.                 singleSelect : true,  
  15.                 url:'getPsNewConsultList.action',  
  16.                 //queryParams:{},  
  17.                 loadMsg:'数据加载中请稍后……',  
  18.                 pagination: true,  
  19.                 rownumbers: true,     
  20.                 columns:[[  
  21.                     {field:'adviceid',title: '来文号',align: 'center',width: getWidth(0.2)},  
  22.                     {field:'consulter',title: '案由',align: 'center',width: getWidth(0.45),  
  23.                         //添加超级链,并将来文号作为参数传入  
  24.                         formatter:function(val,rec){  
  25.                             //alert(rec.adviceid);  
  26.                             return "<a href='jsp/proposal/psconsultview.jsp?id="+rec.adviceid+"'>"+val+"</a>";  
  27.                        }  
  28.                     },  
  29.                     {field:'content',title: '状态',align: 'center',width: getWidth(0.2)},  
  30.                     {field:'replynumber',title: '回复数',align: 'center',width: getWidth(0.05)}                                                          
  31.                 ]]  
  32.             });  
  33. }  
  34.   
  35. //为loadGrid()添加参数  
  36.         var queryParams = $('#cxdm').datagrid('options').queryParams;  
  37.         queryParams.who = who.value;  
  38.         queryParams.type = type.value;  
  39.         queryParams.searchtype = searchtype.value;  
  40.         queryParams.keyword = keyword.value;  
  41.         //重新加载datagrid的数据  
  42.         $("#cxdm").datagrid('reload');  

 

 datagrid添加参数的方式

  1. //为loadGrid()添加参数  
  2. var queryParams = $('#cxdm').datagrid('options').queryParams;  
  3.         queryParams.who = who.value;  
  4.         queryParams.type = type.value;  
  5.         queryParams.searchtype = searchtype.value;  
  6.         queryParams.keyword = keyword.value;  
  7.         //重新加载datagrid的数据  
  8.         $("#cxdm").datagrid('reload');  

 或者直接添加在url中

  1. $('#repeatpspolal').datagrid({  
  2.      title:'重复的未初分提案',  
  3.      loadMsg:"数据加载中,请稍后……",  
  4.      region:'north',  
  5.      url:"getRepeatPs.action?documentnumber="+documentnumber+"&simDegree="+simDegree,  
  6. 。。。。。。  

 

Action层

 

  1. //当前页码  
  2. private int page;  
  3. .........  
  4. //征询意见结果集  
  5. private List<Object> rows;  
  6. ...........  
  7.   
  8. @SuppressWarnings("unchecked")  
  9. public String getPsNewConsultList() throws GlobalException {  
  10.         //获取每页显示的行数  
  11.         int pageRows=10;  
  12.         if(null!=request.getParameter("rows")) {  
  13.             pageRows=Integer.parseInt(request.getParameter("rows").toString());  
  14.         }  
  15.         ...........  
  16.         //获取结果集  
  17.         this.setRows(proposalService.getPsNewConsultList(consulter,consultee,type,psId,psContent,pageRows*(page-1)+1,pageRows*page));  
  18.         //获取总记录数  
  19.         this.setTotal(100);  
  20.         ...............  
  21. }  

 

其中的page由datagrid传入,当用户在datagrid左下角选择每页显示的行数时,datagrid会将该值已参数形式附加到url后面传入action中,名字就叫page,还要将结果总行数total传给datagrid,用于分页

不知道是datagrid配置有误还是datagrid的bug,datagrid的结果集和每页显示的行数都叫rows,重名了

解决办法如上,结果集还是叫rows,但是List的类型改为Object而不能用实体的类型,每页显示的行数通过request获取

 

action配置时,要继承json-default,json-default继承自struts-default,还要配置输出结果类型为json

 

  1. <action name="getPsNewConsultList" class="proposalConsultAction" method="getPsNewConsultList">  
  2.         <result name="success" type="json">  
  3.              <param name="includeProperties">  
  4.                     ^rows\[\d+\]\.\w+,total  
  5.              </param>  
  6.              <param name="noCache">true</param>    
  7.             <param name="ignoreHierarchy">false</param>   
  8.               </result>  
  9.     </action>  

 

service层

 

  1. @SuppressWarnings("unchecked")  
  2.     public List getPsNewConsultList(String consulter,String consultee,String type,String psId,String psContent,int pageRows,int page) throws Exception {  
  3.         return proposalDAO.getPsNewConsultList(consulter,consultee,type,psId,psContent,pageRows,page);  
  4.     }  

 

 

dao层只需要将ResultSet中的数据循环加入实体属性,然后将实体实例加入List即可,形式如下:

 

  1. List<Person> list=new ArrayList<Person>();  
  2. Person person=null;  
  3. while(rs.next())  
  4. {  
  5.     person=new Person();  
  6.     person.setId(i);  
  7.     person.setName("名字"+i);  
  8.     list.add(person);  
  9. }  
  10. .........  
  11. return list;   

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值