Jqgrid入门-结合Struts2+json实现数据展示(五)
DEMO用的是ssh框架实现的,具体怎么搭建的就不多做说明了。分页表格的数据操作难点就是数据展现。至于增删改直接用hibernate原生的方法实现即可。
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
/*** @param pageSize* 每页显示多少条* @param currentPage* 当前页* @param paramMap* 参数* @param sidx* 排序的列* @param sord* 升序or降序* @return*/public Map<?, ?> queryByJQGrid(int pageSize, int currentPage, Map<String, String> paramMap, String sidx, String sord); |
接着我们来实现这个接口。
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
@Overridepublic Map<?, ?> queryByJQGrid(int pageSize, int currentPage, Map<String, String> paramMap, String sidx, String sord) {Map result = new HashMap();List list = null;try {Criteria cr = DetachedCriteria.forClass(Student.class).getExecutableCriteria(this.getSession());if ((paramMap != null) && (paramMap.size() > 0)) {String key = null;String value = null;Iterator ite = paramMap.keySet().iterator();while (ite.hasNext()) {key = (String) ite.next();value = (String) paramMap.get(key);if ((key != null) && (key.trim().length() > 0) && (value != null) && (value.trim().length() > 0)) {cr.add(Restrictions.like(key, "%" + value.trim() + "%"));}}}Integer totcount = (Integer) cr.setProjection(Projections.rowCount()).uniqueResult();cr.setProjection(null).setResultTransformer(Criteria.ROOT_ENTITY);if (!StringUtils.isEmpty(sidx)) {list = cr.addOrder(((sord != null) && (sord.trim().equalsIgnoreCase("asc"))) ? Order.asc(sidx.split(" ")[0]) :Order.desc(sidx.split(" ")[0])).setFirstResult((currentPage - 1) * pageSize).setMaxResults(pageSize).list();}result.put("totalCount", totcount);result.put("dataList", list);} catch (Exception e) {e.printStackTrace();}return result;} |
|
1
2
3
4
5
6
7
8
|
protected List dataList = Collections.emptyList(); //数据集合protected Integer rows = Integer.valueOf(0); //行数protected Integer page = Integer.valueOf(0); //当前页数protected Integer total = Integer.valueOf(0); //数据总页数protected Integer record = Integer.valueOf(0); //数据总条数protected String sord; //排序方式protected String sidx; //排序字段protected String search; |
|
1
2
3
4
5
6
7
8
9
10
11
12
13
|
public String query() {Map<String, String> paramMap = new HashMap<String, String>();Map map = null;if (null != stuName && stuName.trim().length() > 0) {paramMap.put("name", stuName);}map = queryAllStudentService.queryByJQGrid(rows, page, paramMap, sidx, sord);this.dataList = (ArrayList) map.get("dataList");Object totalCount = map.get("totalCount");this.record = Integer.valueOf(Integer.parseInt((totalCount == null) ? "0" : totalCount.toString()));this.total = Integer.valueOf((int) Math.ceil(this.record.intValue() / this.rows.intValue()));return "query_success";} |
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
<package name="student" extends="json-default"><action name="QueryActionUrl_*" method="{1}"><result name="query_success" type="json"><param name="includeProperties">dataList\[\d+\]\.id,dataList\[\d+\]\.name,dataList\[\d+\]\.age,dataList\[\d+\]\.address,dataList\[\d+\]\.class,dataList\[\d+\]\.likedo,dataList\[\d+\]\.phone,dataList\[\d+\]\.sex,rows, page, total,record</param><param name="noCache">true</param><param name="ignoreHierarchy">false</param><param name="contentType">text/html</param></result></action></package> |
注意:在Struts2中使用json还需要json-plagin.jar的支持。不然会抛There is no mapping for namespace异常。如果还有什么不明白的地方,留下你的评论。
原创文章,转载请注明: 转载自java开发者
本文链接地址: Jqgrid入门-结合Struts2+json实现数据展示(五)
Jqgrid入门-结合Struts2+json实现数据展示(五)的更多相关文章
- JqGrid 自定义子表格 及 自定义Json 格式数据不展示
项目第一次使用JqGrid ,发现功能强大,但由于对他不熟悉,也没有少走弯路,记录一下. 1.引用 <link href="~/Scripts/JqGrid/jqgrid/css/ui ...
- Jqgrid入门-使用模态对话框编辑表格数据(三)
Jqgrid是一个强大的表格插件,它提供了多种方式来编辑数据.这三种方式分别是: Cell Editing——只允许修改某一个单元格内容 Inline Editing——允许在jqGr ...
- Struts2+Jquery实现ajax并返回json类型数据
来源于:http://my.oschina.net/simpleton/blog/139212 摘要 主要实现步骤如下: 1.JSP页面使用脚本代码执行ajax请求 2.Action中查询出需要返回的 ...
- Jqgrid入门-Jqgrid列数据拖动(七)
上一章提到在Jqgrid中如何设置二级表头,这一章节主要探讨Jqgrid表格里面的数据如果实现拖动功能,比如你想把第一行的数据拖到当前页的最后一行,或者其他位置. Jqgrid表格插件自己没有 ...
- 转载:Struts2+Jquery实现ajax并返回json类型数据
摘要: 主要实现步骤如下: 1.JSP页面使用脚本代码执行ajax请求 2.Action中查询出需要返回的数据,并转换为json类型模式数据 3.配置struts.xml文件 4.页面脚本接受并处理数 ...
- MVC框架json数据展示程序(第一版)
模型原型:服务器的配置和运行状态信息. 设计要求:Json格式数据解析后,判断配置信息是否是新数据或者是否更新.如是新数据,则直接添加到数据库:若是数据更新,则更新数据库配置信息并更新运行状态信息:都 ...
- Sencha touch 2 入门 -------- DataView 显示服务器端JSON文件数据
今天学习了下DataView如何显示JSON文件数据,废话不多说,直接贴代码: 首先看下文件目录: 然后看下我们要处理的JSON文件,bookInfo.json. { "success&qu ...
- Java入门系列:处理Json格式数据
本节主要讲解: 1)json格式数据处理方法 2)第三方工具包的使用方法 3)java集合数据类型 [项目任务] 编写一个程序,显示未来的天气信息. [知识点解析] 为了方便后面代码的分析,先需要掌握 ...
- Jqgrid入门-Jqgrid设置二级表头(六)
上一章已经说明了Jqgrid结合Struts2+json展示数据,这一章主要探讨Jqgrid如何设置二级表头,类似这样的效果.如: 要实现这个功能,其实也不难.通过Jqgrid的s ...
随机推荐
- ffmpeg 错误码
av_read_frame, av_write_frame等 经常会返回负值也即写数据包失败.不同的负值代表不同的含义,可以根据错误码定义,定位问题. #define EPERM 1 /* Opera ...
- C# 数据结构--排序[下]
希尔排序(Shell Sort) 排序思想: 先取一个小于n的整数d1作为第一个增量,把文件的全部记录分组.所有距离为d1的倍数的记录放在同一个组中.先在各组内进行直接插入排序:然后,取第二个增量d2 ...
- 【转】2-SAT题集
转自:http://blog.csdn.net/shahdza/article/details/7779369 [HDU]3062 Party1824 Let's go home3622 Bomb G ...
- 【BZOJ】【3524】【POI2014】Couriers
可持久化线段树 裸可持久化线段树,把区间第K大的rank改成num即可……(往儿子走的时候不减少) 苦逼的我……MLE了一次(N*30),RE了一次(N*10)……数组大小不会开…… 最后开成N*20 ...
- (转)CentOS5.5 下搭建 PHP 环境(最佳的LAMP环境)
本文详细阐述在 Linux 系统中搭建 PHP 环境,由于 PHP 就是由 C 语言编写的,最初也是运行在 Linux 系统中,所以Linux 是 PHP 的最佳环境. 关于本文中使用到的软件,请点击 ...
- sql2008安装时提示重启计算机失败解决方法
安装sql 2008的时候,在检测安装环境中有一项是”重新启动计算机”显示的结果是“失败”.上网看了半天,找到了解决方案,虽然我没弄明白具体原因,但问题是解决了,解决方案如下: 一.Windows+R ...
- spring mvc 经典总结
概述 继 Spring 2.0 对 Spring MVC 进行重大升级后,Spring 2.5 又为 Spring MVC 引入了注解驱动功能.现在你无须让 Controller 继承任何接口,无需在 ...
- Json.net/Newtonsoft 3.0 新特性JObject/Linq to Json
原文:http://www.cnblogs.com/chsword/archive/2008/09/19/Newtonsoft_new_3_0.html http://www.cnblogs.com/ ...
- POJ3250Bad Hair Day
http://poj.org/problem?id=3250 题意 : n个牛排成一列向右看,牛 i 能看到牛 j 的头顶,当且仅当牛 j 在牛 i 的右边并且牛 i 与牛 j 之间的所有牛均比牛 ...
- 将集成spring的项目从tomcat上移植到weblogic下存在的问题
当在weblogic下部署时, 1.需要jersey-servlet-xx.jar,jersey-core-xx.jar,jersey-server-xx.jar: 2.在web.xml中全局参数co ...