- 浏览: 87492 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
elfasd:
有个问题,现在最新的flexgrid是不是不支持showche ...
JQuery 插件FlexiGrid 之完全配置与使用 -
chembo:
很用心,谢谢!
JQuery 插件FlexiGrid 之完全配置与使用 -
zhangxiaofei2012:
asdfsdfffffffffffff
JQuery 插件FlexiGrid 之完全配置与使用 -
jacking124:
严重: Error loading WebappClassLo ...
JQuery 插件FlexiGrid 之完全配置与使用-续{附Demo+Data} -
axxxman:
笑纳了 可以运行的
JQuery 插件FlexiGrid 之完全配置与使用-续{附Demo+Data}
自己再做这个的时候.也是找了很多资料..但网上搜索了很多资料. 没有介绍的很全的.
鄙人就在此献丑一下. 来全面的介绍一下JQuery FlexiGrid插件的配置和实用.
本人很菜. 各位大拿看了这么菜的文章 就不要拍砖了.. 一笑而过.好吗?谢谢合作.
首先.去下载FlexGrid http://www.flexigrid.info/
下载完成后.解压开有__MACOSX和flexigrid两个文件夹
主要使用flexigrid里面的文件
flexgrid文件夹下文件如下
..
准备工作完成后
真正工作开始了
在MyEclipse下新建Web project..
把flexigrid包下所有的文件拷贝到WebRoot/下
新建*.jsp页面
body体中
加入
做完flexigrid控件的显示容器. 没有则不会显示控件
页面引入控件代码
flexgrid参数介绍:
注意:
Head标签必须要引入
jquery.js、flexigrid.css、flexigrid.js
三个主要文件
自己要根据自己的文件路径.去引入css\js文件
页面完成启动tomcat测试页面会不会显示控件.
应该是没有问题的,只是没有数据
主要的还是后台的操作
这里由于时间关系只介绍select方法了.
可以看到flex无刷新的路径是一个servlet.看看servlet做了些什么?
首先接收路径传过来的hidden值.
因为后面我会根据hidden值做各种操作.所以url重写了一些字段.大家可以不用如此.
可以看到许多request.getParameter("***");
是后去flexigrid控件的一些参数.
大家可以到flexigrid.js文件里面看到这些参数.
page//获取当前的页数.
rp//每页显示多少行数据
query//点击放大镜出现搜索功能,是Input文本框的值
qtype//是搜索功能后面的select的值
根据query的操作判断是模糊查询还是全部查询数据.
Servlet全部代码看完了.
看看.Dao层的数据层的代码吧.
主要引用Dao的代码如下
主要代码1.
rid为ReleaseInfoDao的实例对象(发布信息表)
首先我们来看getReleaseInfoCount()方法
主要代码2.
这里看到返回的是json格式的数据
主要Dao层方法为creReleaseInfoJSON();getReleaseInfo(int pageIndex,int pageSize);方法
getReleaseInfo代码如下
上述方法的SQL为Oracle的分页查询.MS SQL、MySql等.其他数据库不适用.
creReleaseInfoJSON代码如下:
返回的JSON格式的数据:
JSONObject代码在下面的附件里有.
还有需要解释的地方.
大家可以看到dao
并没有
Connection
PreparedStatement
ResultSet
等对象.
我操作数据使用的是.
commons-dbutils-1.1.jar(下面的附件中也包含有.)
整体的介绍完了.
可以说比较考验个人读代码的能力.个人细心的能力.
上述代码.应该是没有问题的.
因为我测试一点问题没有.
可能是因为您配置或者书写代码的问题..
可能会出现这样那样的困难.
也请不要进行人身攻击.
在做这个的时候.我也碰到许多问题。
耐心些。 没有解决不了的问题.
鄙人写代码很烂. 各位大牛们 就不要拍砖了. 凑活看就行了.
如果什么问题.
请到本人博客留言.
只要是本人会的
定会尽力解决.
花费半个点的功夫.整理一下.. 各位笑纳了.
遗留问题:点击标题.自动排序的问题.. 如果哪位哥们解决了.. 请在本人博客留言.
十分感谢您的帮助
Ps: 很感谢 ayeah 同学..
在此以前. 一直认为是flexgrid. 实际正确的拼写为flexigrid. 十分低级的错误.
呵呵. 还望各位同学见谅.
项目源码:请到这里下载JQuery 插件FlexiGrid 之完全配置与使用-续{附Demo+Data}
当时只研究了Flexigrid...
下面的答案. 是别人告诉我的. 因为没有时间测试. 所以不清楚对与错.
----------------
sortname: "PINO",
sortorder: "desc",
数据第一次加载时是按这个排序的,这以后你每次点击某一列,都会从后台取一次数据并更新grid,你只要在后台用
# getRequest().getParameter("sortorder")
# getRequest().getParameter("sortname")
拿到sortorder和sortname,带着这两个参数查询,就可以实现点哪一列按哪一列排序了
-------------------
仅供参考.
.. 排序那个 后来一直没在搞. 也就不了了之了..
.. 呵呵.
.. 你可以在flexigrid.js 里面看到 它模糊查询 <select> 的 id 是 qtype.
.. 而文本输入框的 id 是query..
.. 你在servlet 里面 接受这两个值. 拼接SQL 就可以实现你所需要的 模糊查询了.
.. 当然这需要你在
searchitems 就是它的模糊查询 后面的name. 字段 需要跟你数据库的字段 完全一致. 才会正确的返回数据.
..
如还有不懂. 可给我留言.
前一段时间 一直忙 没有时间看je. 回复的晚了些. 请见谅.~
楼主不厚道,光贴代码咋看啊,好歹也要运行起来再看这样才方便啊
效果可以去flexigrid官网去
呵呵.. 以前项目开发时候做的. 代码也是扒下来的..
所以没有可运行的demo.
效果可以到flexigrid的官网去欣赏一下吧..
呵呵.. 如果自己需要稍微整理一下实现思路. 应该很好实现.
不能太懒了. 代码都懒得打了. 如果不需要. 一眼过一下. 知道有这么个东西就行了.
现在网络上flexigrid的示例有不少. 但都不深入.
楼主不厚道,光贴代码咋看啊,好歹也要运行起来再看这样才方便啊
感觉 应该是这里的问题.
我使用Servlet
使用response.getWriter().write(jsonStr);
Struts2. 在Action中 也 应该使用response对象 去响应数据?
直接使用Mapping.findForward("success");
应该是不可以的吧. 并没有json数据的返回.
您说呢?
是啊,servlet是response.write输出json数据。struts2那怎么在flexigrid接受返回数据呢?
楼主能不能换成struts2的服务端试试
呵呵. 我没用过Struts2啊. Struts 我只使用过Struts1.x.
你看看这种思路 行不行.
不继承Struts的跳转方式. 自己去构造response跳转. 然后把json数据绑定到response对象里面.
就是
response.getWriter().write(jsonStr);
虽然这样就违背了Struts的原理. 但为了查看问题的根本 测试一下 还是可以的.
行吗?我测试怎么不行啊
感觉 应该是这里的问题.
我使用Servlet
使用response.getWriter().write(jsonStr);
Struts2. 在Action中 也 应该使用response对象 去响应数据?
直接使用Mapping.findForward("success");
应该是不可以的吧. 并没有json数据的返回.
您说呢?
是啊,servlet是response.write输出json数据。struts2那怎么在flexigrid接受返回数据呢?
楼主能不能换成struts2的服务端试试
呵呵. 我没用过Struts2啊. Struts 我只使用过Struts1.x.
你看看这种思路 行不行.
不继承Struts的跳转方式. 自己去构造response跳转. 然后把json数据绑定到response对象里面.
就是
response.getWriter().write(jsonStr);
虽然这样就违背了Struts的原理. 但为了查看问题的根本 测试一下 还是可以的.
感觉 应该是这里的问题.
我使用Servlet
使用response.getWriter().write(jsonStr);
Struts2. 在Action中 也 应该使用response对象 去响应数据?
直接使用Mapping.findForward("success");
应该是不可以的吧. 并没有json数据的返回.
您说呢?
是啊,servlet是response.write输出json数据。struts2那怎么在flexigrid接受返回数据呢?
楼主能不能换成struts2的服务端试试
鄙人就在此献丑一下. 来全面的介绍一下JQuery FlexiGrid插件的配置和实用.
本人很菜. 各位大拿看了这么菜的文章 就不要拍砖了.. 一笑而过.好吗?谢谢合作.
首先.去下载FlexGrid http://www.flexigrid.info/
下载完成后.解压开有__MACOSX和flexigrid两个文件夹
主要使用flexigrid里面的文件
flexgrid文件夹下文件如下
..
准备工作完成后
真正工作开始了
在MyEclipse下新建Web project..
把flexigrid包下所有的文件拷贝到WebRoot/下
新建*.jsp页面
body体中
加入
<table id="flex1" style="display:none"></table>
做完flexigrid控件的显示容器. 没有则不会显示控件
页面引入控件代码
<table id="flex1" style="display:none"></table> <input id="hidden" type="hidden" name="hidden" value="null" /> <script> $("#flex1").flexigrid ( { url: '../ReleaseInfoServlet?hidden=manage', dataType: 'json', colModel : [ {display: '信息编号', name : 'RINO', width : 50, sortable : true, align: 'center',hide: false}, {display: '信息标题', name : 'RITITLE', width : 250, sortable : true, align: 'center'}, {display: '信息类别', name : 'IC.ICNAME', width : 100, sortable : true, align: 'center'}, {display: '信息热点', name : 'RIHOTPOINT', width : 60, sortable : true, align: 'center'}, <!--{display: '信息内容', name : 'RICONTENT', width : 100, sortable : true, align: 'center'},--> {display: '发布日期', name : 'RIDATE', width : 120, sortable : true, align: 'center'}, {display: '发布作者', name : 'RIAUTHOR', width : 80, sortable : true, align: 'center'} ], buttons : [ {name: '添加', bclass: 'add', onpress : button}, {name: '删除', bclass: 'delete', onpress : button}, {name: '修改', bclass: 'modify', onpress : button}, {separator: true} ], searchitems : [ {display: '信息编号', name : 'RINO', isdefault: true}, {display: '信息标题', name : 'RITITLE'}, {display: '信息类别', name : 'IC.ICNAME'}, {display: '发布作者', name : 'RIAUTHOR'} ], sortname: "RINO", sortorder: "desc", usepager: true, title: '信息发布管理', useRp: true, rp: 20, showTableToggleBtn: true, width: 780, height: 300 } ); function button(com,grid) { if (com=='删除') { ${"hidden"}.value="delete"; if($('.trSelected',grid).length==0){ alert("请选择要删除的数据"); }else{ if(confirm('是否删除这 ' + $('.trSelected',grid).length + ' 条记录吗?')) { var id =""; for(var i=0;i<$('.trSelected',grid).length;i++){ if(i==$('.trSelected',grid).length-1){ id += "id="+$('.trSelected',grid).find("td:first").eq(i).text(); } else { id += "id="+$('.trSelected',grid).find("td:first").eq(i).text()+"&"; } } window.location.href="../ReleaseInfoServlet?hidden="+${"hidden"}.value+"&"+id; } } } else if (com=='添加') { ${"hidden"}.value="add"; window.location.href="infoAdd.jsp?hidden="+${"hidden"}.value; } else if (com=='修改') { ${"hidden"}.value="modify"; if($(".trSelected").length==1){ window.location.href="infoAdd.jsp?hidden="+${"hidden"}.value+"&id="+$('.trSelected',grid).find("td").eq(0).text(); }else if($(".trSelected").length>1){ alert("请选择一个修改,不能同时修改多个"); }else if($(".trSelected").length==0){ alert("请选择一个您要修改的新闻信息") } } }
flexgrid参数介绍:
height: 200, //flexigrid插件的高度,单位为px width: ‘auto’, //宽度值,auto表示根据每列的宽度自动计算 striped: true, //是否显示斑纹效果,默认是奇偶交互的形式 novstripe: false, minwidth: 30, //列的最小宽度 minheight: 80, //列的最小高度 resizable: true, //是否可伸缩 url: false, //ajax方式对应的url地址 method: ‘POST’, // 数据发送方式 dataType: ‘xml’, // 数据加载的类型 errormsg: ‘Connection Error’,//错误提升信息 usepager: false, //是否分页 nowrap: true, //是否不换行 page: 1, //默认当前页 total: 1, //总页面数 useRp: true, //是否可以动态设置每页显示的结果数 rp: 15, // 每页默认的结果数 rpOptions: [10,15,20,25,40],//可选择设定的每页结果数 title: false,//是否包含标题 pagestat: ‘Displaying {from} to {to} of {total} items’,//显示当前页和总页面的样式 procmsg: ‘Processing, please wait …’,//正在处理的提示信息 query: ”,//搜索查询的条件 qtype: ”,//搜索查询的类别 nomsg: ‘No items’,//无结果的提示信息 minColToggle: 1, //minimum allowed column to be hidden showToggleBtn: true, //show or hide column toggle popup hideOnSubmit: true,//隐藏提交 autoload: true,//自动加载 blockOpacity: 0.5,//透明度设置 onToggleCol: false,//当在行之间转换时 onChangeSort: false,//当改变排序时 onSuccess: false,//成功后执行 onSubmit: false // 调用自定义的计算函数
注意:
Head标签必须要引入
<link rel="stylesheet" href="css/flexigrid/flexigrid.css" type="text/css"></link> <script type="text/javascript" src="lib/jquery/jquery.js"></script> <script type="text/javascript" src="js/flexigrid.js"></script>
jquery.js、flexigrid.css、flexigrid.js
三个主要文件
自己要根据自己的文件路径.去引入css\js文件
页面完成启动tomcat测试页面会不会显示控件.
应该是没有问题的,只是没有数据
主要的还是后台的操作
这里由于时间关系只介绍select方法了.
可以看到flex无刷新的路径是一个servlet.看看servlet做了些什么?
response.setContentType("text/html;charset=UTF-8"); ReleaseInfoDao rid = new ReleaseInfoDao(); String hidden = request.getParameter("hidden"); PrintWriter out = response.getWriter();
首先接收路径传过来的hidden值.
因为后面我会根据hidden值做各种操作.所以url重写了一些字段.大家可以不用如此.
if(hidden.equals("manage")){ // 获得当前页数 String pageIndex = request.getParameter("page"); // 获得每页数据最大量 String pageSize = request.getParameter("rp"); // 获得模糊查询文本输入框的值 String query = new String(request.getParameter("query").getBytes("ISO8859-1"),"UTF-8"); // 获得模糊查询条件 String qtype = request.getParameter("qtype"); if(query==""||("").equals(query)){ Map pageInfo = new HashMap(); pageInfo.put("page", pageIndex); pageInfo.put("total", rid.getReleaseInfoCount()); // 数据JSON格式化 String jsonStr = rid.creReleaseInfoJSON(rid.getReleaseInfo(Integer.parseInt(pageIndex), Integer.parseInt(pageSize)), pageInfo); // response相关处理 response.setContentType("html/txt"); response.setCharacterEncoding("utf-8"); response.setHeader("Pragma", "no-cache"); response.setHeader("Cache-Control", "no-cache, must-revalidate"); response.setHeader("Pragma", "no-cache"); try { response.getWriter().write(jsonStr); response.getWriter().flush(); response.getWriter().close(); } catch (IOException e) { e.printStackTrace(); } }else{ Map pageInfo = new HashMap(); pageInfo.put("page", pageIndex); pageInfo.put("total", rid.getReleaseInfoCountLike(qtype, query)); // 数据JSON格式化 String jsonStr = rid.creReleaseInfoJSON(rid.getReleaseInfoLike(Integer.parseInt(pageIndex), Integer.parseInt(pageSize), qtype, query), pageInfo); // response相关处理 response.setContentType("html/txt"); response.setCharacterEncoding("utf-8"); response.setHeader("Pragma", "no-cache"); response.setHeader("Cache-Control", "no-cache, must-revalidate"); response.setHeader("Pragma", "no-cache"); try { response.getWriter().write(jsonStr); response.getWriter().flush(); response.getWriter().close(); } catch (IOException e) { e.printStackTrace(); } } }
可以看到许多request.getParameter("***");
是后去flexigrid控件的一些参数.
大家可以到flexigrid.js文件里面看到这些参数.
page//获取当前的页数.
rp//每页显示多少行数据
rp: 20,
query//点击放大镜出现搜索功能,是Input文本框的值
qtype//是搜索功能后面的select的值
根据query的操作判断是模糊查询还是全部查询数据.
Servlet全部代码看完了.
看看.Dao层的数据层的代码吧.
主要引用Dao的代码如下
主要代码1.
pageInfo.put("total", rid.getReleaseInfoCount()); String jsonStr = rid.creReleaseInfoJSON(rid.getReleaseInfo(Integer.parseInt(pageIndex), Integer.parseInt(pageSize)), pageInfo);
rid为ReleaseInfoDao的实例对象(发布信息表)
首先我们来看getReleaseInfoCount()方法
/** * 获得信息表所有的数据量, * 并返回数据个数 * @return */ public long getReleaseInfoCount(){ long count =0l; QueryRunner queryRunner = new QueryRunner(); String query = "select count(*) as num from TB_ReleaseInfo"; try { Map map = (Map)queryRunner.query(DBConnection.getConnection(), query, new MapHandler()); count = Long.parseLong(map.get("num").toString()); } catch (SQLException e) { e.printStackTrace(); } finally { DBConnection.close(); } return count; }
主要代码2.
String jsonStr = rid.creReleaseInfoJSON(rid.getReleaseInfo(Integer.parseInt(pageIndex), Integer.parseInt(pageSize)), pageInfo);
这里看到返回的是json格式的数据
主要Dao层方法为creReleaseInfoJSON();getReleaseInfo(int pageIndex,int pageSize);方法
getReleaseInfo代码如下
/** * 分页查询 * @param pageIndex * @param pageSize * @return */ public List getReleaseInfo(int pageIndex,int pageSize){ List releaseInfoList = new ArrayList(); int beginIndex = (pageIndex-1)*pageSize; int endIndex = pageIndex*pageSize; QueryRunner queryRunner = new QueryRunner(); String query = "select * from (" + "select rownum rn,rino,rititle,ritype,icname,rihotpoint,ricontent,ridate,riauthor " + "from (" + "select ri.rino,ri.rititle,ri.ritype,ic.icname,ri.rihotpoint,ri.ricontent,ri.ridate,ri.riauthor" + " from TB_ReleaseInfo ri ,TB_InfoCategroy ic where ri.ritype = ic.icno " + "order by ri.rino desc) where rownum<=?) where rn>?"; try { releaseInfoList = (List)queryRunner.query(DBConnection.getConnection(), query,new Object[]{new Integer(endIndex),new Integer(beginIndex)},new MapListHandler()); } catch (SQLException e) { e.printStackTrace(); } finally { DBConnection.close(); } return releaseInfoList; }
上述方法的SQL为Oracle的分页查询.MS SQL、MySql等.其他数据库不适用.
creReleaseInfoJSON代码如下:
/** * 数据JSON格式化 * @param list * @param pageInfo * @return */ public String creReleaseInfoJSON(List list,Map pageInfo){ String jsonStr = ""; List mapList = new ArrayList(); for(int i=0;i<list.size();i++){ Map cellMap = new HashMap(); cellMap.put("id", ((Map)list.get(i)).get("RINo").toString()); cellMap.put("cell", new Object[]{ ((Map)list.get(i)).get("RINo"), ((Map)list.get(i)).get("RITitle"), ((Map)list.get(i)).get("ICName"), ((Map)list.get(i)).get("RIHotpoint"), ((Map)list.get(i)).get("RIDATE"), ((Map)list.get(i)).get("RIAuthor") }); mapList.add(cellMap); } pageInfo.put("rows", mapList); JSONObject object = new JSONObject(pageInfo); jsonStr = object.toString(); return jsonStr; }
返回的JSON格式的数据:
jsonStr{"total":3,"page":"1","rows":[{"id":"8","cell":[8,"啊啊","什么玩意","否","2009-06-24 14:30:11","admin"]},{"id":"7","cell":[7,"来挑心底1","媒体声音","是","2009-06-24 14:29:55","admin"]},{"id":"3","cell":[3,"新茶品","最热新闻","否","2009-06-24 13:55:00","admin"]}]}
JSONObject代码在下面的附件里有.
还有需要解释的地方.
大家可以看到dao
并没有
Connection
PreparedStatement
ResultSet
等对象.
我操作数据使用的是.
commons-dbutils-1.1.jar(下面的附件中也包含有.)
整体的介绍完了.
可以说比较考验个人读代码的能力.个人细心的能力.
上述代码.应该是没有问题的.
因为我测试一点问题没有.
可能是因为您配置或者书写代码的问题..
可能会出现这样那样的困难.
也请不要进行人身攻击.
在做这个的时候.我也碰到许多问题。
耐心些。 没有解决不了的问题.
鄙人写代码很烂. 各位大牛们 就不要拍砖了. 凑活看就行了.
如果什么问题.
请到本人博客留言.
只要是本人会的
定会尽力解决.
花费半个点的功夫.整理一下.. 各位笑纳了.
遗留问题:点击标题.自动排序的问题.. 如果哪位哥们解决了.. 请在本人博客留言.
十分感谢您的帮助
Ps: 很感谢 ayeah 同学..
在此以前. 一直认为是flexgrid. 实际正确的拼写为flexigrid. 十分低级的错误.
呵呵. 还望各位同学见谅.
项目源码:请到这里下载JQuery 插件FlexiGrid 之完全配置与使用-续{附Demo+Data}
- 需要文件.rar (163.9 KB)
- 下载次数: 2955
评论
50 楼
elfasd
2013-05-09
有个问题,现在最新的flexgrid是不是不支持showcheckbox方法了?
49 楼
chembo
2012-11-27
很用心,谢谢!
48 楼
zhangxiaofei2012
2012-01-24
asdfsdfffffffffffff
47 楼
zhangpurple
2011-08-31
不错,[[flash=200,200][/flash]
46 楼
yernyou
2010-03-26
代码 很好看的说
45 楼
Darrick
2010-03-25
flyingcai 写道
与 jqgird相比,会更好用吗? 有两者都有用过的吗?
当时只研究了Flexigrid...
44 楼
flyingcai
2010-03-24
与 jqgird相比,会更好用吗? 有两者都有用过的吗?
43 楼
Darrick
2010-02-01
shenger 写道
关于前台table的排序楼主有答案了么?
我现在在静态html里添加了flexigrid控制的table,可是点击表头数据不能排序。
相关url:http://www.iteye.com/problems/34680
如有结果,请与我联系。谢谢!
我现在在静态html里添加了flexigrid控制的table,可是点击表头数据不能排序。
相关url:http://www.iteye.com/problems/34680
如有结果,请与我联系。谢谢!
下面的答案. 是别人告诉我的. 因为没有时间测试. 所以不清楚对与错.
----------------
sortname: "PINO",
sortorder: "desc",
数据第一次加载时是按这个排序的,这以后你每次点击某一列,都会从后台取一次数据并更新grid,你只要在后台用
# getRequest().getParameter("sortorder")
# getRequest().getParameter("sortname")
拿到sortorder和sortname,带着这两个参数查询,就可以实现点哪一列按哪一列排序了
-------------------
仅供参考.
42 楼
Darrick
2010-02-01
shenger 写道
关于前台table的排序楼主有答案了么?
我现在在静态html里添加了flexigrid控制的table,可是点击表头数据不能排序。
相关url:http://www.iteye.com/problems/34680
如有结果,请与我联系。谢谢!
我现在在静态html里添加了flexigrid控制的table,可是点击表头数据不能排序。
相关url:http://www.iteye.com/problems/34680
如有结果,请与我联系。谢谢!
.. 排序那个 后来一直没在搞. 也就不了了之了..
.. 呵呵.
41 楼
Darrick
2010-02-01
zhongxiu 写道
不好意思呢,打扰了,我知道怎么弄了呢!不过在使用的过程中,遇到了另外一个问题,那就是我输入查询条件后,按了回车键可以根据条件查询一次,为什么第二次,输入查询条件后,在按回车键的时候,并不会再次调用后台的代码呢?很期待你的指教。
.. 你可以在flexigrid.js 里面看到 它模糊查询 <select> 的 id 是 qtype.
.. 而文本输入框的 id 是query..
.. 你在servlet 里面 接受这两个值. 拼接SQL 就可以实现你所需要的 模糊查询了.
.. 当然这需要你在
searchitems : [ {display: '信息编号', name : 'RINO', isdefault: true}, {display: '信息标题', name : 'RITITLE'}, {display: '信息类别', name : 'IC.ICNAME'}, {display: '发布作者', name : 'RIAUTHOR'} ],
searchitems 就是它的模糊查询 后面的name. 字段 需要跟你数据库的字段 完全一致. 才会正确的返回数据.
..
如还有不懂. 可给我留言.
前一段时间 一直忙 没有时间看je. 回复的晚了些. 请见谅.~
40 楼
zhongxiu
2010-01-27
不好意思呢,打扰了,我知道怎么弄了呢!不过在使用的过程中,遇到了另外一个问题,那就是我输入查询条件后,按了回车键可以根据条件查询一次,为什么第二次,输入查询条件后,在按回车键的时候,并不会再次调用后台的代码呢?很期待你的指教。
39 楼
zhongxiu
2010-01-27
首先非常感谢你提供这么详细的资料,但是现在我想请教你一个问题:因为查询项有很多种,那么我在后台处理的时候:我的sql语句怎么写呢?我如何知道是根据数据表里面哪个字段进行模糊查询呢?就像我的查询项有编号,名称,内容,如果我选名称项的时候,那我再后台怎么判断我是选的名称项呢?
38 楼
kjj
2010-01-20
恭喜楼主,写着么详细的介绍,本来我也想用这个东东的,结果遇到难题,然后跑到他们google group上去问,果然很多人在那里问问题,结果第一个问题,作者的回答就是,这个项目已经停止更新了,不再开发,现在替代品是jqgride,这个玩意了!!!!!!!!!!!!!
因此,考虑转到jqgride吧
因此,考虑转到jqgride吧
37 楼
shenger
2010-01-20
关于前台table的排序楼主有答案了么?
我现在在静态html里添加了flexigrid控制的table,可是点击表头数据不能排序。
相关url:http://www.iteye.com/problems/34680
如有结果,请与我联系。谢谢!
我现在在静态html里添加了flexigrid控制的table,可是点击表头数据不能排序。
相关url:http://www.iteye.com/problems/34680
如有结果,请与我联系。谢谢!
36 楼
Darrick
2009-11-27
gundumw100 写道
bingki 写道
本来想看看fg的效果,但你这东西代码给的太乱,连接数据哭的类没有,更别说数据库结构了,难到还要大家看着你的SQL语句,自己再去建设表啊!
唉,都用了附件,干吗不把完整的项目放进去。
唉,都用了附件,干吗不把完整的项目放进去。
楼主不厚道,光贴代码咋看啊,好歹也要运行起来再看这样才方便啊
效果可以去flexigrid官网去
呵呵.. 以前项目开发时候做的. 代码也是扒下来的..
所以没有可运行的demo.
效果可以到flexigrid的官网去欣赏一下吧..
呵呵.. 如果自己需要稍微整理一下实现思路. 应该很好实现.
不能太懒了. 代码都懒得打了. 如果不需要. 一眼过一下. 知道有这么个东西就行了.
现在网络上flexigrid的示例有不少. 但都不深入.
35 楼
gundumw100
2009-11-27
bingki 写道
本来想看看fg的效果,但你这东西代码给的太乱,连接数据哭的类没有,更别说数据库结构了,难到还要大家看着你的SQL语句,自己再去建设表啊!
唉,都用了附件,干吗不把完整的项目放进去。
唉,都用了附件,干吗不把完整的项目放进去。
楼主不厚道,光贴代码咋看啊,好歹也要运行起来再看这样才方便啊
34 楼
gundumw100
2009-11-27
楼主能不能把完整的工程放上来啊,谢谢了
33 楼
zhongaili520
2009-11-24
Darrick 写道
zhongaili520 写道
zhongaili520 写道
Darrick 写道
zhongaili520 写道
是啊,我也是用struts2,怎么就是不显示
try { response.getWriter().write(jsonStr); response.getWriter().flush(); response.getWriter().close(); } catch (IOException e) { e.printStackTrace(); }
感觉 应该是这里的问题.
我使用Servlet
使用response.getWriter().write(jsonStr);
Struts2. 在Action中 也 应该使用response对象 去响应数据?
直接使用Mapping.findForward("success");
应该是不可以的吧. 并没有json数据的返回.
您说呢?
是啊,servlet是response.write输出json数据。struts2那怎么在flexigrid接受返回数据呢?
楼主能不能换成struts2的服务端试试
呵呵. 我没用过Struts2啊. Struts 我只使用过Struts1.x.
你看看这种思路 行不行.
HttpServletResponse response = (HttpServletResponse)ctx.get(ServletActionContext.HTTP_RESPONSE);
不继承Struts的跳转方式. 自己去构造response跳转. 然后把json数据绑定到response对象里面.
就是
response.getWriter().write(jsonStr);
虽然这样就违背了Struts的原理. 但为了查看问题的根本 测试一下 还是可以的.
行吗?我测试怎么不行啊
32 楼
Darrick
2009-11-24
zhongaili520 写道
zhongaili520 写道
Darrick 写道
zhongaili520 写道
是啊,我也是用struts2,怎么就是不显示
try { response.getWriter().write(jsonStr); response.getWriter().flush(); response.getWriter().close(); } catch (IOException e) { e.printStackTrace(); }
感觉 应该是这里的问题.
我使用Servlet
使用response.getWriter().write(jsonStr);
Struts2. 在Action中 也 应该使用response对象 去响应数据?
直接使用Mapping.findForward("success");
应该是不可以的吧. 并没有json数据的返回.
您说呢?
是啊,servlet是response.write输出json数据。struts2那怎么在flexigrid接受返回数据呢?
楼主能不能换成struts2的服务端试试
呵呵. 我没用过Struts2啊. Struts 我只使用过Struts1.x.
你看看这种思路 行不行.
HttpServletResponse response = (HttpServletResponse)ctx.get(ServletActionContext.HTTP_RESPONSE);
不继承Struts的跳转方式. 自己去构造response跳转. 然后把json数据绑定到response对象里面.
就是
response.getWriter().write(jsonStr);
虽然这样就违背了Struts的原理. 但为了查看问题的根本 测试一下 还是可以的.
31 楼
zhongaili520
2009-11-24
zhongaili520 写道
Darrick 写道
zhongaili520 写道
是啊,我也是用struts2,怎么就是不显示
try { response.getWriter().write(jsonStr); response.getWriter().flush(); response.getWriter().close(); } catch (IOException e) { e.printStackTrace(); }
感觉 应该是这里的问题.
我使用Servlet
使用response.getWriter().write(jsonStr);
Struts2. 在Action中 也 应该使用response对象 去响应数据?
直接使用Mapping.findForward("success");
应该是不可以的吧. 并没有json数据的返回.
您说呢?
是啊,servlet是response.write输出json数据。struts2那怎么在flexigrid接受返回数据呢?
楼主能不能换成struts2的服务端试试
发表评论
-
JQuery 插件FlexiGrid 之完全配置与使用-续{附Demo+Data}
2010-03-22 11:09 7618感觉很对不住JE的大哥们, 很早之前的一篇博客, 如您想要查看 ... -
吸血鬼数字 高效算法
2010-03-11 23:43 1709提前声明. 此算法来自 【老紫竹】. 老紫竹CSDN ID: ... -
MyEclipse 7.5,Flex Builder 3.0,IDE整合
2010-03-09 15:24 32461.下载MyEclipse官方原版地址: 官方原版 或者:h ... -
jxl 工具包读取 excel文件
2009-06-26 11:21 1733package *****; import java ... -
[转载]CVS 标签与分支
2009-05-22 13:18 4906转载至IBM【ECLIPSE 小组 ... -
[转载]CVS的简单使用-模块签入签出以及日常操作
2009-05-21 22:21 4364转载至IBM【ECLIPSE 小组开发环境实践: 第 1 部分 ... -
[转载]windows下安装CVS以及与Eclipse建立连接
2009-05-20 01:31 5066转载至IBM【ECLIPSE 小组开发环境实践: 第 1 部分 ... -
Jsp页面验证码的生成方法
2009-05-19 13:29 3256image.jsp---------------------- ... -
Jsp连接MySql数据库方法
2009-05-19 13:17 3107首先先将MySql的数据库连接驱动拷贝到Tomcat/comm ...
相关推荐
### JQuery插件FlexiGrid之完全配置与使用 #### 一、引言 FlexiGrid是一款基于jQuery的轻量级表格插件,它为开发者提供了简单易用的方式来展示和操作数据表格。FlexiGrid支持多种功能,如排序、分页、筛选等,非常...
1. **jQuery基础**:Flexigrid是建立在jQuery库之上的,因此,理解jQuery的基本语法和API,如选择器、事件处理、DOM操作等,是使用Flexigrid的前提。jQuery简化了JavaScript的DOM操作,使得动态更新表格内容变得更加...
JQuery FlexiGrid 插件是一款强大的数据网格组件,用于在网页中展示和管理结构化的数据。它提供了丰富的功能,包括排序、分页、搜索、编辑和自定义操作按钮等。下面将详细介绍FlexiGrid的配置和使用方法。 首先,你...
综上所述,FlexiGrid是一个强大的jQuery插件,它能帮助开发者快速构建具有高级特性的数据表格。通过灵活配置和丰富的API,你可以根据项目需求定制出满足各种需求的表格组件。在实际应用中,记得结合自己的数据源和...
《jQuery插件flexigrid使用总结与进一步优化》 在Web开发中,数据展示和交互是不可或缺的一部分。jQuery插件flexigrid是一款轻量级、功能强大的表格插件,能够帮助开发者快速构建具有分页、排序、搜索等功能的动态...
总的来说,jQuery插件flexigrid是一个强大的工具,为Web开发人员提供了一种高效的数据展示解决方案。通过深入理解和应用,你可以创建出具有专业水准的数据管理界面,提升用户的操作体验。对于PHP开发者来说,它更是...
Tablesorter是一个轻量级的jQuery插件,它可以对HTML表格进行排序,无需任何服务器端的支持。 接下来,我们需要对Flexigrid的表格元素应用Tablesorter。首先,确保已经正确引入了Tablesorter的相关库,然后在页面...
总的来说,"jquery插件之flexigrid学习实例-jar包"是一个实践教程,旨在帮助开发者理解如何将Flexigrid这个强大的jQuery插件与Struts2和JSON技术结合,以构建高效、交互性强的Web应用表格功能。这个实例涉及到了前端...
在这个"jquery插件之flexigrid学习实例"中,我们将深入探讨如何在Struts2框架下结合JSON进行数据交互,以实现一个完整的应用。 首先,我们需要了解Flexigrid的基本使用方法。在HTML页面中,我们需要引入jQuery库和...
jQuery Flexigrid是一款基于jQuery库的表格插件,专为网页数据展示提供强大的功能。它具有高度可定制性,支持分页、排序、搜索以及自定义列宽,使得网页中的数据管理更加便捷和灵活。 Flexigrid的核心特性在于其...
总结来说,Flexigrid是jQuery生态中一款功能强大、易于使用的表格插件,对于需要展示和操作表格数据的Web应用来说,是一个值得考虑的选择。通过熟练掌握其配置和API,开发者可以构建出高性能、交互性强的数据展示...
3. **配置与依赖** Struts2的版本必须为2.1.6,否则可能会导致配置错误。在`web.xml`中需正确配置Struts2的标签库,确保使用的`struts2-core`版本与配置相符,避免出现`JasperException`。 4. **页面结构与JS初始...
6. 插件扩展:利用jQuery插件机制,编写自己的扩展插件,实现更高级的功能,如拖拽列宽、列隐藏、列排序方式切换等。 通过以上介绍,我们可以了解到FlexiGrid的基本使用、功能扩展以及可能的改造方向。在实际开发中...
**jQuery FlexiGrid JS** 是一个强大的前端数据网格插件,它基于流行的JavaScript库jQuery构建。这个插件允许用户在网页上展示大量数据,并提供排序、分页、搜索和自定义列功能,使得数据管理更加直观和高效。下面将...
总的来说,Flexigrid是一款强大的jQuery网格插件,通过与servlet配合,可以构建出高效、易用的数据展示和管理界面。开发者需要掌握其配置、事件、数据绑定等核心概念,以便在实际项目中灵活运用。
FlexiGrid是一款基于JQuery的表格插件,用于在网页中展示数据,具有分页、排序、筛选等功能,常用于后台管理系统中数据的展示。它提供了丰富的配置选项和灵活的扩展性,使得开发者可以根据需求定制表格的行为和样式...
Jquery与Flexigrid结合,可以动态加载和分页显示表格数据。 4. **Flexigrid 使用** Flexigrid是一款强大的表格组件,提供了排序、分页、搜索等功能。在HTML页面中,我们需要引入Flexigrid的CSS和JS文件,并在表格...
### Jquery Flexigrid 使用详解 #### 技术栈概览 本文档旨在介绍如何结合Struts2.1.6、Spring、Hibernate、jQuery、Flexigrid、Thickbox及MySQL来实现一个功能完整的Web应用。该应用的核心是通过Flexigrid在前端...