该帖已经被评为隐藏帖
|
|
---|---|
作者 | 正文 |
发表时间:2011-06-20
最后修改:2011-06-24
第一部分:案例效果 第二部分:实战-下载案例工程和部署案例 第三部分:功能和代码实现介绍 本案例大致功能描述如下: 1.通过bbossgroups 控制器方法返回对象,然后mvc框架将对象转换为json对象返回给jquery easyui datagrid展示 2.jquery easyui datagrid通过指定对应控制器方法的请求url来获取datagrid的数据,然后展示出来 3.同时结合jquery easyui portal插件来做界面集成展示。 第一部分 案例效果 介绍之前先看下效果图: 第二部分 实战部署指南: 1 下载示例工程 http://dl.iteye.com/topics/download/5d678bd7-439b-3b0c-8577-94dce98a99c4 2.将mvc工程导入eclipse,并编译通过 3.准备好tomcat 6和jdk 15或以上 4 在tomcat 6的conf\Catalina\localhost下增加datagride.xml文件,内容为: <?xml version='1.0' encoding='utf-8'?> <Context docBase="D:\workspace\easyuidatagrid\WebRoot" path="/datagride" debug="0" reloadable="false"> </Context> 用户可以根据自己的情况设置docBase属性的值 5.启动tomcat,输入以下地址即可访问本实例了,呵呵: http://localhost:8080/datagride/examples/index.page 应该可以看到上述的效果示意图中的界面了。 第三部分 功能介绍和代码实现: 3.下面看控制器的实现: package org.frameworkset.mvc; import java.util.ArrayList; import java.util.List; import org.frameworkset.util.annotations.RequestParam; import org.frameworkset.util.annotations.ResponseBody; /** * <p>PortalController.java</p> * <p> Description: </p> * <p> bboss workgroup </p> * <p> Copyright (c) 2009 </p> * @Date 2011-6-19 * @author biaoping.yin * @version 1.0 */ public class EasyUIDatagridController { private static List<Address> addresses ; static { addresses = new ArrayList<Address>(); for(int i = 0; i < 10000; i ++) { Address address = new Address(); address.setAddr("地址-" + i); address.setCode("代码-" + i); address.setCol4("col4 数据-" + i); address.setName("名称" + i); addresses.add(address); } } public String index() { return "path:portal"; } public @ResponseBody(datatype="json") Addresses datagrid_data_pagine(@RequestParam(name="page",defaultvalue="1") int page,@RequestParam(name="rows",defaultvalue="10") int rows) { return pagerList(addresses,(page - 1)*rows,rows); } public @ResponseBody(datatype="json") GouWuChe datagrid_data_footer() { GouWuChe container = new GouWuChe(); container.setTotal(28); List<Productor> rows = new ArrayList<Productor>(); for(int i = 0; i < 28; i ++) rows.add( buildProductor(i)); container.setRows(rows); container.setFooter(buildFooterProductor()); return container; } private Productor buildProductor(int i) { Productor p = new Productor(); p.setProductid("FI-SW-0" + i); p.setUnitcost(10.00 + i); p.setStatus("P"); p.setListprice(16.50 + i); if(i % 3 == 0) p.setAttr1("桃子"); else if(i % 3 == 1) p.setAttr1("火龙果"); if(i % 3 == 2) p.setAttr1("芒果"); p.setItemid("EST-" + i); return p; } private List<Productor> buildFooterProductor() { Productor p = new Productor(); p.setProductid("Average:" ); p.setUnitcost(19.80); p.setListprice(60.40); List<Productor> footer = new ArrayList<Productor>(); footer.add(p); p = new Productor(); p.setProductid("Total:" ); p.setUnitcost(198.00); p.setListprice(604.00); footer.add(p); return footer; } /** * 对列表进行分页操作,数据源是一个列表 * @param datas 列表数据 * @param offset 获取数据的起始位置 * @param pageItems 获取数据的条数 * @return ListInfo 对分页数据和总记录条数的封装类 */ private static Addresses pagerList(List datas,int offset,int pageItems) { if(datas == null) return null; List list = new ArrayList(); if(offset >= datas.size()) { int temp = datas.size() % pageItems; offset = datas.size() - temp; } for(int i = offset; i < datas.size() && i < offset + pageItems; i ++) { list.add(datas.get(i)); } Addresses address = new Addresses(); address.setRows(list); address.setTotal(datas.size()); return address; } } 4.依赖的po对象-GouWuChe 和Productor,GouWuChe对象将被转换为json对象,是根据jquery easyui datagrid要求的结构定义的json对象容器,包含的产品对象Productor是具体的po记录对象。 GouWuChe 对象的结构如下: public class GouWuChe { private long total;//总记录数 private List<Productor> rows;//要显示的记录 private List<Productor> footer;//统计页脚,包含平均价格和总价格 //get和set方法,省略掉 } Productor对象结构如下,包含产品的所有属性: public class Productor { private String productid; private double unitcost; private String status; private double listprice; private String attr1; private String itemid; //get和set方法,省略掉 } 5.依赖的po对象-Addresses 和Address,Addresses 对象将被转换为json对象,是根据jquery easyui 分页datagrid要求的结构定义的json对象容器,包含的产品对象Address是具体的po记录对象。 Addresses对象结构如下,包含产品的所有属性: public class Addresses { private long total; private List<Address> rows; //get和set方法,省略掉 } Addresses对象结构如下,包含产品的所有属性: public class Address { private String code; private String name; private String addr; private String col4; //get和set方法,省略掉 } 6.mvc控制器配置: <properties> <property name="/examples/*.page" path:portal="/examples/portal.jsp" class="org.frameworkset.mvc.EasyUIDatagridController"> </property> </properties> 7.再来看看jquery easyui datagrid页面代码-portal.jsp: <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Bboss mvc demo -jQuery EasyUI DataGrid Portal</title> <link rel="stylesheet" type="text/css" href="../include/themes/default/easyui.css"> <link rel="stylesheet" type="text/css" href="../include/themes/icon.css"> <link rel="stylesheet" type="text/css" href="../include/jquery-easyui-portal/portal.css"> <style type="text/css"> .title{ font-size:16px; font-weight:bold; padding:20px 10px; background:#eee; overflow:hidden; border-bottom:1px solid #ccc; } .t-list{ padding:5px; } </style> <script type="text/javascript" src="../include/jquery-1.4.4.min.js"></script> <script type="text/javascript" src="../include/jquery.easyui.min.js"></script> <script type="text/javascript" src="../include/jquery-easyui-portal/jquery.portal.js"></script> <script> $(function(){ $('#pp').portal({ border:false, fit:true }); //add(); $('#test').datagrid({ iconCls:'icon-save', width:600, height:350, fit:true,border:false, nowrap: false, striped: true, url:'datagrid_data_pagine.page', sortName: 'code', sortOrder: 'desc', remoteSort: false, idField:'code', frozenColumns:[[ {field:'ck',checkbox:true}, {title:'code',field:'code',width:80,sortable:true} ]], columns:[[ {title:'Base Information',colspan:3}, {field:'opt',title:'Operation',width:100,align:'center', rowspan:2, formatter:function(value,rec){ return '<span style="color:red">Edit Delete</span>'; } } ],[ {field:'name',title:'Name',width:120}, {field:'addr',title:'Address',width:120,rowspan:2,sortable:true, sorter:function(a,b){ return (a>b?1:-1); } }, {field:'col4',title:'Col41',width:150,rowspan:2} ]], pagination:true, rownumbers:true, toolbar:[{ id:'btnadd', text:'Add', iconCls:'icon-add', handler:function(){ $('#btnsave').linkbutton('enable'); alert('add') } },{ id:'btncut', text:'Cut', iconCls:'icon-cut', handler:function(){ $('#btnsave').linkbutton('enable'); alert('cut') } },'-',{ id:'btnsave', text:'Save', disabled:true, iconCls:'icon-save', handler:function(){ $('#btnsave').linkbutton('disable'); alert('save') } }] }); var p = $('#test').datagrid('getPager'); if (p){ $(p).pagination({ onBeforeRefresh:function(){ alert('before refresh'); } }); } }); } </script> </head> <body class="easyui-layout"> <div region="center" border="false"> <div id="pp" style="position:relative"> <div style="width:40%;"> <div title="Clock" collapsible="true" closable="true" style="text-align:center;background:#f3eeaf;height:150px;padding:5px;"> <object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,29,0" width="100" height="100"> <param name="movie" value="http://www.respectsoft.com/onlineclock/analog.swf"> <param name=quality value=high> <param name="wmode" value="transparent"> <embed src="http://www.respectsoft.com/onlineclock/analog.swf" width="100" height="100" quality=high pluginspage="http://www.macromedia.com/shockwave/download/index.cgi?P1_Prod_Version=ShockwaveFlash" type="application/x-shockwave-flash" wmode="transparent"></embed> </object> </div> <div id="pgrid" title="DataGrid" collapsible="true" closable="true" style="height:300px;"> <table class="easyui-datagrid" style="width:650px;height:auto" fit="true" border="false" singleSelect="true" idField="itemid" url="datagrid_data_footer.page" showFooter="true"> <thead> <tr> <th field="itemid" width="60">Item ID</th> <th field="productid" width="60">Product ID</th> <th field="listprice" width="80" align="right">List Price</th> <th field="unitcost" width="80" align="right">Unit Cost</th> <th field="attr1" width="120">Attribute</th> <th field="status" width="50" align="center">Status</th> </tr> </thead> </table> </div> </div> <div style="width:60%;"> <div id="pgrid-1" title="DataGrid" collapsible="true" closable="true" style="height:350px;"> <table id="test"> </table> </div> </div> </div> </div> </body> </html> 所有的内容就介绍完了。 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2011-06-21
很不错,顶一个。
|
|
返回顶楼 | |
发表时间:2011-06-23
沙发。。。很不错。。portal效果很绚
|
|
返回顶楼 | |
发表时间:2011-06-23
t22011787 写道 沙发。。。很不错。。portal效果很绚
嗯,可以下载附件工程感受一把哦 |
|
返回顶楼 | |
发表时间:2011-06-23
群主,很牛!
|
|
返回顶楼 | |
发表时间:2011-06-23
群主,很牛!
|
|
返回顶楼 | |
发表时间:2011-06-23
顶上,不错..... : 功能强劲
|
|
返回顶楼 | |
发表时间:2011-06-23
支持楼主更新,我个人有点不太喜欢extjs的样子。
弱弱的说一句:bbossgroups这个名字,太长了点。 |
|
返回顶楼 | |
发表时间:2011-06-23
ericslegend 写道 支持楼主更新,我个人有点不太喜欢extjs的样子。
弱弱的说一句:bbossgroups这个名字,太长了点。 嗯,大家有合适名字的话,可以发给我,呵呵 |
|
返回顶楼 | |
发表时间:2011-06-23
ericslegend 写道 支持楼主更新,我个人有点不太喜欢extjs的样子。
弱弱的说一句:bbossgroups这个名字,太长了点。 这个是用jquery easyui的portal插件,后台用的bbossgroups的mvc框架实现的,不是extjs哦。 |
|
返回顶楼 | |