1.使用准备

前台需要的资源文件,主要有Bootstrap3相关css、js以及bootstrap Table相关css、js:

  1. <-- 样式 -->
  2. <link rel="stylesheet" href="bootstrap.min.css">
  3. <link rel="stylesheet" href="bootstrap-table.css">
  4. <script src="jquery.min.js"></script>
  5. <script src="bootstrap.min.js"></script>
  6. <script src="bootstrap-table.js"></script>
  7. <-- 表格汉化js -->
  8. <script src="bootstrap-table-zh-CN.js"></script>

以上这些插件可以到这里下载http://bootstrap-table.wenzhixin.NET.cn/zh-cn/getting-started/ (官方文档地址)。

2.使用方法

对于bootstrap table 可以通过data 属性或者JavaScript 来启用bootstrap table 插件,显示丰富的功能。

这里推荐使用javascript来启用bootstrap table插件来使用bootstrap table,可以实现js和html的分离,代码可以重用,下面我介绍的时候也只介绍这种方法。

3.前端代码

页面代码:

  1. <-- 以下是一些需要的css、js -->
  2. <-- 样式 -->
  3. <link rel="stylesheet" href="bootstrap.min.css">
  4. <link rel="stylesheet" href="bootstrap-table.css">
  5. <script src="jquery.min.js"></script>
  6. <script src="bootstrap.min.js"></script>
  7. <script src="bootstrap-table.js"></script>
  8. <-- 表格汉化js -->
  9. <script src="bootstrap-table-zh-CN.js"></script>
  10. <-- 这是html主体代码,只需要这一个就可以了 -->
  11. <div ><table id="tableList" class="table table-striped"></table> </div>

以上代码省略了部分html标签,只粘贴了主要部分。

js代码:

  1. //通过bootstrap Table方法refresh重新加载数据
  2. function showData() {
  3. $('#tableList').bootstrapTable('refresh');
  4. }
  5. //官方使用方法的语法:<code>$('#table').bootstrapTable('method', parameter)</code>
  6. $('#tableList').bootstrapTable({
  7. columns: [{
  8. field: 'id',
  9. title: '序号',
  10. }, {
  11. field: 'year',
  12. title: '年度',
  13. }, {
  14. field: 'month',
  15. title: '月份',
  16. },{
  17. field: 'creDate',
  18. title: '日期',
  19. },{
  20. field: 'merBasicId',
  21. title: '商户id',
  22. },{
  23. field: 'merName',
  24. title: '商户名称',
  25. },{
  26. field: 'categoryTypeName',
  27. title: '商户类型',
  28. },{
  29. field: 'city',
  30. title: '城市',
  31. },{
  32. field: 'area',
  33. title: '区域',
  34. },{
  35. field: 'tradeAreaName',
  36. title: '商圈',
  37. }],//页面需要展示的列,后端交互对象的属性
  38. pagination: true,  //开启分页
  39. sidePagination: 'server',//服务器端分页
  40. pageNumber: 1,//默认加载页
  41. pageSize: 20,//每页数据
  42. pageList: [20, 50, 100, 500],//可选的每页数据
  43. queryParams: function (params) {
  44. return {
  45. startDate: $("#txtStartDate").val(),
  46. endDate: $("#txtEndDate").val(),
  47. merName: $("#txtMerName").val(),
  48. pageSize: params.limit,
  49. offset: params.offset
  50. }
  51. },//请求服务器数据时的参数
  52. url: rootURL+'/console/finance/channelDivideDetails/data' //服务器数据的加载地址
  53. });

对于parameter更多的描述,具体可以参考前面发的官方文档的链接。

4.后端代码

  1. //根据传入的pageSize,offset参数决定查哪一页,根据其他参数决定查询哪些数据
  2. @RequestMapping( value = "/data", method = RequestMethod.POST, produces = "application/json;charset=UTF-8" )
  3. @ResponseBody
  4. public Object channelDivideDetailsData( HttpServletRequest request, @RequestBody JSONObject jsonObj ) {
  5. String html = "[]";
  6. Map<String, Object> map = new HashMap<String, Object>();
  7. String startDateStr = jsonObj.getString("startDate");
  8. String endDateStr = jsonObj.getString("endDate");
  9. String merName = jsonObj.getString("merName");
  10. int pageSize = jsonObj.getIntValue("pageSize");
  11. int offset = jsonObj.getIntValue("offset");
  12. try {
  13. map.put("startDate", startDateStr);
  14. map.put("endDate", endDateStr);
  15. if(merName != null && merName != "") {
  16. map.put("merName", merName);
  17. }
  18. PageBounds pageBounds = JSPUtil.getPagerBoundsByParameter(pageSize, offset);
  19. List<FChannelDivideDetails> list = channelDivideDetailsService.getChannelDivideDetails(map, pageBounds);
  20. if(list != null && list.size() > 0) {
  21. Map<String, Object> retMap =
  22. (Map<String, Object>) JSPUtil.pagelistToJSONMapNew((PageList<FChannelDivideDetails>) list);
  23. html = JSON.toJSONStringWithDateFormat(retMap, DATE_FORMATE_STR);
  24. }
  25. }
  26. catch(Exception e) {
  27. logger.error("系统异常e:{}", e);
  28. this.buildResponse(ErrorCode.system_1000);
  29. }
  30. return html;
  31. }

4.1这里要注意的是前端传过来的参数是json格式的,所以用@RequestBody注解后我们就能将前端传过来的参数取出来。

4.2代码里用到了mybatis的一个分页插件mybatis-paginator,我们只需要包装出一个PageBounds,参数传入service层,插件会自动帮我们代理实现分页,就不需要我们自己再写分页代码了, mybatis-paginator的具体使用教程搜索关键字查看相关文章即可。

包装PageBounds的代码:

  1. /**
  2. * 取得分页对象
  3. *
  4. * @param pageSize
  5. * @param offset
  6. * @return
  7. */
  8. @SuppressWarnings( "unused" )
  9. public static PageBounds getPagerBoundsByParameter( int pageSize, int offset ) {
  10. if(pageSize == 0) {
  11. return null;
  12. }
  13. PageBounds pageBounds = new PageBounds(offset / pageSize + 1, pageSize);
  14. return pageBounds;
  15. }

4.3最后返回前端的json数据包括total、rows两个对象,total表示数据总数,rows表示需要显示的数据。必须按照这种格式返回才行。

包装返回数据的代码:

  1. @SuppressWarnings( { "rawtypes", "unchecked" } )
  2. public static Object pagelistToJSONMapNew( PageList list ) {
  3. Map<String, Object> map = new HashMap<String, Object>();
  4. if(list != null) {
  5. Paginator paginator = list.getPaginator();
  6. map.put("total", paginator.getTotalCount());
  7. map.put("rows", new ArrayList(list));
  8. }
  9. return map;
  10. }

以上就实现了从前端到后端的表格分页查询。

目前主要使用到了查询分页,具体其他的操作可以参考查询相关代码。

bootstrap table + spring + springmvc + mybatis 实现从前端到后端的表格分页的更多相关文章

  1. Spring+SpringMVC+MyBatis整合进阶篇(四)RESTful实战(前端代码修改)

    前言 前文<RESTful API实战笔记(接口设计及Java后端实现)>中介绍了RESTful中后端开发的实现,主要是接口地址修改和返回数据的格式及规范的修改,本文则简单介绍一下,RES ...

  2. 【SSM之旅】Spring+SpringMVC+MyBatis+Bootstrap整合基础篇(一)项目简介及技术选型相关介绍

    试水 一直想去搭建个自己的个人博客,苦于自己的技术有限,然后也个人也比较懒散.想动而不能动,想动而懒得动,就这么一直拖到了现在.总觉得应该把这几年来的所学总结一番,这样才能有所成长. 不知在何时,那就 ...

  3. 用 eclipse 创建一个简单的 meaven spring springMvc mybatis 项目

    下面是整体步骤: 1: 先创建一个Maven 项目: 选择跳过骨架: 因为要搭建的是 web 项目  所以这个地方选择 war 包; 点击完成 这样就完成 Maven项目的搭建: 接下俩 先把 Mav ...

  4. SSM(Spring,SpringMVC,Mybatis)框架整合项目

    快速上手SSM(Spring,SpringMVC,Mybatis)框架整合项目 环境要求: IDEA MySQL 8.0.25 Tomcat 9 Maven 3.6 数据库环境: 创建一个存放书籍数据 ...

  5. Spring+SpringMVC+MyBatis+easyUI整合优化篇(七)图片上传功能

    日常啰嗦 前一篇文章<Spring+SpringMVC+MyBatis+easyUI整合优化篇(六)easyUI与富文本编辑器UEditor整合>讲了富文本编辑器UEditor的整合与使用 ...

  6. javaweb项目-医者天下 (Spring+SpringMVC+MyBatis)

    项目下载地址:http://download.csdn.net/detail/qq_33599520/9826683 项目完整结构图: 项目简介: 医者天下项目是一个基于Spring+SpringMV ...

  7. Spring+SpringMVC+MyBatis深入学习及搭建(十二)——SpringMVC入门程序(一)

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6999743.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(十一)——S ...

  8. Spring+SpringMVC+MyBatis深入学习及搭建(十二)——SpringMVC入门程序

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6999743.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(十一)--S ...

  9. Spring+SpringMVC+MyBatis深入学习及搭建(十四)——SpringMVC和MyBatis整合

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/7010363.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(十三)--S ...

随机推荐

  1. C/C++ 关于 for循环 的第二个表达式右侧非常量的时候

    废话不多说,直接看代码: #include<stdio.h> int main(){ ; ;z<zmax;z++){ printf("i=%d z=%d\n",i ...

  2. 分享一个Panda C-60 维修心得

    昨天丰臣国际搞了个汽车后备箱市场,说白了就是一帮闲的没事儿的"白领"大热天把自家闲置的东西拿过来练练摊,这个形式还是不错的,中间看到了一个熊猫的CD机,一眼就看上了,虽说CD早就过 ...

  3. 【转】QT 串口QSerialPort + 解决接收数据不完整问题

    类:QSerialPort 例程:Examples\Qt-5.9.1\serialport\terminal,该例子完美展示了qt串口收发过程,直接在这上面修改就可以得到自己的串口软件.核心方法 // ...

  4. go语言之进阶篇单向channel特点

    1.单向channel特点 package main //"fmt" func main() { //创建一个channel, 双向的 ch := make(chan int) / ...

  5. Windbg命令学习15(bp bm bu bl bc ba断点)

    以下以skinhgy为例,windbg附加运行 1. bp 命令是在某个地址下断点, 可以 bp 0x7783FEB 也可以 bp MyApp!SomeFunction . 对于后者,WinDBG 会 ...

  6. LeetCode 754. Reach a Number到达终点数字

    题目 在一根无限长的数轴上,你站在0的位置.终点在target的位置. 每次你可以选择向左或向右移动.第 n 次移动(从 1 开始),可以走 n 步. 返回到达终点需要的最小移动次数. 示例 1: 输 ...

  7. (转)unity3D 如何提取游戏资源 (反编译)+代码反编译

    原帖:http://bbs.9ria.com/thread-401140-1-1.html 首先感谢 雨松MOMO 的一篇帖子 教我们怎么提取 .ipa 中的游戏资源.教我们初步的破解unity3d资 ...

  8. BitNami

    BitNami 提供wordpress.joomla.drupal.bbpress等开源程序的傻瓜式安装包下载,所有的安装包内置了服务器环境,就是说,不需要在本地 电脑上另外搭建服务器,就可以一次性傻 ...

  9. HotSpot Java虚拟机中的“方法区”“持久代”“元数据区”的关系?

    Sun/Oracle JDK的HotSpot VM中,直到JDK7都有“持久代”(Permanent Generation,简称PermGen).也称为方法区.Oracle JDK8的HotSpot ...

  10. CentOS7安装 Apache HTTP 服务器

    CentOS7安装 Apache HTTP 服务器 时间:2015-05-02 00:45来源:linux.cn 作者:linux.cn 举报 点击:11457次 不管你因为什么原因使用服务器,大部分 ...