本文介绍bbossgroups mvc结合jquery easyui datagrid portal的一个简单案例,分3部分:
第一部分:案例效果
第二部分:实战-下载案例工程和部署案例
第三部分:功能和代码实现介绍
本案例大致功能描述如下:
1.通过bbossgroups 控制器方法返回对象,然后mvc框架将对象转换为json对象返回给jquery easyui datagrid展示
2.jquery easyui datagrid通过指定对应控制器方法的请求url来获取datagrid的数据,然后展示出来
3.同时结合jquery easyui portal插件来做界面集成展示。
第一部分 案例效果
介绍之前先看下效果图:
第二部分 实战部署指南:
1 下载示例工程
http://dl.iteye.com/topics/download/0f97d852-03c3-39af-a8ee-a0108fb3530c
2.将mvc工程导入eclipse,并编译通过
3.准备好tomcat 6和jdk 15或以上
4 在tomcat 6的conf\Catalina\localhost下增加datagride.xml文件,内容为:
用户可以根据自己的情况设置docBase属性的值
5.启动tomcat,输入以下地址即可访问本实例了,呵呵:
http://localhost:8080/datagride/examples/index.page
应该可以看到上述的效果示意图中的界面了。
第三部分 功能介绍和代码实现:
3.下面看控制器的实现:
4.依赖的po对象-GouWuChe 和Productor,GouWuChe对象将被转换为json对象,是根据jquery easyui datagrid要求的结构定义的json对象容器,包含的产品对象Productor是具体的po记录对象。
GouWuChe 对象的结构如下:
Productor对象结构如下,包含产品的所有属性:
5.依赖的po对象-Addresses 和Address,Addresses 对象将被转换为json对象,是根据jquery easyui 分页datagrid要求的结构定义的json对象容器,包含的产品对象Address是具体的po记录对象。
Addresses对象结构如下,包含产品的所有属性:
Addresses对象结构如下,包含产品的所有属性:
6.mvc控制器配置:
7.再来看看jquery easyui datagrid页面代码-portal.jsp:
所有的内容就介绍完了。
第一部分:案例效果
第二部分:实战-下载案例工程和部署案例
第三部分:功能和代码实现介绍
本案例大致功能描述如下:
1.通过bbossgroups 控制器方法返回对象,然后mvc框架将对象转换为json对象返回给jquery easyui datagrid展示
2.jquery easyui datagrid通过指定对应控制器方法的请求url来获取datagrid的数据,然后展示出来
3.同时结合jquery easyui portal插件来做界面集成展示。
第一部分 案例效果
介绍之前先看下效果图:
第二部分 实战部署指南:
1 下载示例工程
http://dl.iteye.com/topics/download/0f97d852-03c3-39af-a8ee-a0108fb3530c
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>
所有的内容就介绍完了。