bootstrap table + spring + springmvc + mybatis 实现从前端到后端的表格分页
1.使用准备
前台需要的资源文件,主要有Bootstrap3相关css、js以及bootstrap Table相关css、js:
- <-- 样式 -->
- <link rel="stylesheet" href="bootstrap.min.css">
- <link rel="stylesheet" href="bootstrap-table.css">
- <script src="jquery.min.js"></script>
- <script src="bootstrap.min.js"></script>
- <script src="bootstrap-table.js"></script>
- <-- 表格汉化js -->
- <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.前端代码
页面代码:
- <-- 以下是一些需要的css、js -->
- <-- 样式 -->
- <link rel="stylesheet" href="bootstrap.min.css">
- <link rel="stylesheet" href="bootstrap-table.css">
- <script src="jquery.min.js"></script>
- <script src="bootstrap.min.js"></script>
- <script src="bootstrap-table.js"></script>
- <-- 表格汉化js -->
- <script src="bootstrap-table-zh-CN.js"></script>
- <-- 这是html主体代码,只需要这一个就可以了 -->
- <div ><table id="tableList" class="table table-striped"></table> </div>
以上代码省略了部分html标签,只粘贴了主要部分。
js代码:
- //通过bootstrap Table方法refresh重新加载数据
- function showData() {
- $('#tableList').bootstrapTable('refresh');
- }
- //官方使用方法的语法:<code>$('#table').bootstrapTable('method', parameter)</code>
- $('#tableList').bootstrapTable({
- columns: [{
- field: 'id',
- title: '序号',
- }, {
- field: 'year',
- title: '年度',
- }, {
- field: 'month',
- title: '月份',
- },{
- field: 'creDate',
- title: '日期',
- },{
- field: 'merBasicId',
- title: '商户id',
- },{
- field: 'merName',
- title: '商户名称',
- },{
- field: 'categoryTypeName',
- title: '商户类型',
- },{
- field: 'city',
- title: '城市',
- },{
- field: 'area',
- title: '区域',
- },{
- field: 'tradeAreaName',
- title: '商圈',
- }],//页面需要展示的列,后端交互对象的属性
- pagination: true, //开启分页
- sidePagination: 'server',//服务器端分页
- pageNumber: 1,//默认加载页
- pageSize: 20,//每页数据
- pageList: [20, 50, 100, 500],//可选的每页数据
- queryParams: function (params) {
- return {
- startDate: $("#txtStartDate").val(),
- endDate: $("#txtEndDate").val(),
- merName: $("#txtMerName").val(),
- pageSize: params.limit,
- offset: params.offset
- }
- },//请求服务器数据时的参数
- url: rootURL+'/console/finance/channelDivideDetails/data' //服务器数据的加载地址
- });
对于parameter更多的描述,具体可以参考前面发的官方文档的链接。
4.后端代码
- //根据传入的pageSize,offset参数决定查哪一页,根据其他参数决定查询哪些数据
- @RequestMapping( value = "/data", method = RequestMethod.POST, produces = "application/json;charset=UTF-8" )
- @ResponseBody
- public Object channelDivideDetailsData( HttpServletRequest request, @RequestBody JSONObject jsonObj ) {
- String html = "[]";
- Map<String, Object> map = new HashMap<String, Object>();
- String startDateStr = jsonObj.getString("startDate");
- String endDateStr = jsonObj.getString("endDate");
- String merName = jsonObj.getString("merName");
- int pageSize = jsonObj.getIntValue("pageSize");
- int offset = jsonObj.getIntValue("offset");
- try {
- map.put("startDate", startDateStr);
- map.put("endDate", endDateStr);
- if(merName != null && merName != "") {
- map.put("merName", merName);
- }
- PageBounds pageBounds = JSPUtil.getPagerBoundsByParameter(pageSize, offset);
- List<FChannelDivideDetails> list = channelDivideDetailsService.getChannelDivideDetails(map, pageBounds);
- if(list != null && list.size() > 0) {
- Map<String, Object> retMap =
- (Map<String, Object>) JSPUtil.pagelistToJSONMapNew((PageList<FChannelDivideDetails>) list);
- html = JSON.toJSONStringWithDateFormat(retMap, DATE_FORMATE_STR);
- }
- }
- catch(Exception e) {
- logger.error("系统异常e:{}", e);
- this.buildResponse(ErrorCode.system_1000);
- }
- return html;
- }
4.1这里要注意的是前端传过来的参数是json格式的,所以用@RequestBody注解后我们就能将前端传过来的参数取出来。
4.2代码里用到了mybatis的一个分页插件mybatis-paginator,我们只需要包装出一个PageBounds,参数传入service层,插件会自动帮我们代理实现分页,就不需要我们自己再写分页代码了, mybatis-paginator的具体使用教程搜索关键字查看相关文章即可。
包装PageBounds的代码:
- /**
- * 取得分页对象
- *
- * @param pageSize
- * @param offset
- * @return
- */
- @SuppressWarnings( "unused" )
- public static PageBounds getPagerBoundsByParameter( int pageSize, int offset ) {
- if(pageSize == 0) {
- return null;
- }
- PageBounds pageBounds = new PageBounds(offset / pageSize + 1, pageSize);
- return pageBounds;
- }
4.3最后返回前端的json数据包括total、rows两个对象,total表示数据总数,rows表示需要显示的数据。必须按照这种格式返回才行。
包装返回数据的代码:
- @SuppressWarnings( { "rawtypes", "unchecked" } )
- public static Object pagelistToJSONMapNew( PageList list ) {
- Map<String, Object> map = new HashMap<String, Object>();
- if(list != null) {
- Paginator paginator = list.getPaginator();
- map.put("total", paginator.getTotalCount());
- map.put("rows", new ArrayList(list));
- }
- return map;
- }
以上就实现了从前端到后端的表格分页查询。
目前主要使用到了查询分页,具体其他的操作可以参考查询相关代码。
bootstrap table + spring + springmvc + mybatis 实现从前端到后端的表格分页的更多相关文章
- Spring+SpringMVC+MyBatis整合进阶篇(四)RESTful实战(前端代码修改)
前言 前文<RESTful API实战笔记(接口设计及Java后端实现)>中介绍了RESTful中后端开发的实现,主要是接口地址修改和返回数据的格式及规范的修改,本文则简单介绍一下,RES ...
- 【SSM之旅】Spring+SpringMVC+MyBatis+Bootstrap整合基础篇(一)项目简介及技术选型相关介绍
试水 一直想去搭建个自己的个人博客,苦于自己的技术有限,然后也个人也比较懒散.想动而不能动,想动而懒得动,就这么一直拖到了现在.总觉得应该把这几年来的所学总结一番,这样才能有所成长. 不知在何时,那就 ...
- 用 eclipse 创建一个简单的 meaven spring springMvc mybatis 项目
下面是整体步骤: 1: 先创建一个Maven 项目: 选择跳过骨架: 因为要搭建的是 web 项目 所以这个地方选择 war 包; 点击完成 这样就完成 Maven项目的搭建: 接下俩 先把 Mav ...
- SSM(Spring,SpringMVC,Mybatis)框架整合项目
快速上手SSM(Spring,SpringMVC,Mybatis)框架整合项目 环境要求: IDEA MySQL 8.0.25 Tomcat 9 Maven 3.6 数据库环境: 创建一个存放书籍数据 ...
- Spring+SpringMVC+MyBatis+easyUI整合优化篇(七)图片上传功能
日常啰嗦 前一篇文章<Spring+SpringMVC+MyBatis+easyUI整合优化篇(六)easyUI与富文本编辑器UEditor整合>讲了富文本编辑器UEditor的整合与使用 ...
- javaweb项目-医者天下 (Spring+SpringMVC+MyBatis)
项目下载地址:http://download.csdn.net/detail/qq_33599520/9826683 项目完整结构图: 项目简介: 医者天下项目是一个基于Spring+SpringMV ...
- Spring+SpringMVC+MyBatis深入学习及搭建(十二)——SpringMVC入门程序(一)
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6999743.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(十一)——S ...
- Spring+SpringMVC+MyBatis深入学习及搭建(十二)——SpringMVC入门程序
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6999743.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(十一)--S ...
- Spring+SpringMVC+MyBatis深入学习及搭建(十四)——SpringMVC和MyBatis整合
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/7010363.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(十三)--S ...
随机推荐
- 京东的Netty实践,京麦TCP网关长连接容器架构
背景 早期京麦搭建 HTTP 和 TCP 长连接功能主要用于消息通知的推送,并未应用于 API 网关.随着逐步对 NIO 的深入学习和对 Netty 框架的了解,以及对系统通信稳定能力越来越高的要求, ...
- Guava之FluentIterable使用示例
FluentIterable 是guava集合类中常用的一个类,主要用于过滤.转换集合中的数据:FluentIterable是一个抽象类,实现了Iterable接口,大多数方法都返回FluentIte ...
- Leap Motion 上手体验
很早之前就关注了Leap Motion这个颠覆性的体感操作设备,如今7月22日上市至今已经一个月左右,淘宝的价格也已经降到650元,虽说相对国外还是偏贵,但是已经忍不住尝尝鲜了. Leap Motio ...
- 相声段子:How Are You
/**************************************************************** File name : HowAreYou Author : 叶飞影 ...
- jQuery-append添加元素click无效
很久没有使用jQuery,做项目的时候遇到一个小问题就是网页加载之后的append的元素是可以执行click事件,网页加载完成之后的,再次append的元素不执行click事件,简单的通过ul模拟一下 ...
- 华为推送 简介 集成 MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- Hadoop概念学习系列之Hadoop、Spark学习路线(很值得推荐)
说在前面的话 此笔,对于仅对于Hadoop和Spark初中学者.高手请忽略! 1 Java基础: 视频方面: 推荐<毕向东JAVA基础视频教程>.学习hadoop不需要过 ...
- Android Studio快速集成讯飞SDK实现文字朗读功能
今天,我们来学习一下怎么在Android Studio快速集成讯飞SDK实现文字朗读功能,先看一下效果图: 第一步 :了解TTS语音服务 TTS的全称为Text To Speech,即“从文本到语音” ...
- Vim 命令、操作、快捷键全集
Vim是一个类似于Vi的著名的功能强大.高度可定制的文本编辑器,在Vi的基础上改进和增加了很多特性.Vim是自由软件. 命令历史 以:和/开头的命令都有历史纪录,可以首先键入:或/然后按上下箭头来选择 ...
- Java-JUC(八):使用wait,notify|notifyAll完成生产者消费者通信,虚假唤醒(Spurious Wakeups)问题出现场景,及问题解决方案。
模拟通过线程实现消费者和订阅者模式: 首先,定义一个店员:店员包含进货.卖货方法:其次,定义一个生产者,生产者负责给店员生产产品:再者,定义一个消费者,消费者负责从店员那里消费产品. 店员: /** ...