bootstrap table分页(前后端两种方式实现)
bootstrap table分页的两种方式:
前端分页:一次性从数据库查询所有的数据,在前端进行分页(数据量小的时候或者逻辑处理不复杂的话可以使用前端分页)
服务器分页:每次只查询当前页面加载所需要的那几条数据
bootstrap 下载地址:bootstrap下载
bootstrap-table 下载地址:bootstrap-table下载
jquery下载地址:jquery下载
分页效果(请忽略样式)

一:准备js、css等文件
▶ 将下载的文档直接放入webapp目录下

▶页面引入需要的js、css
- <!-- 引入的css文件 -->
- <link href="bootstrap/css/bootstrap.min.css" rel="stylesheet" />
- <link href="bootstrap-table/dist/bootstrap-table.min.css"
- rel="stylesheet">
- <!-- 引入的js文件 -->
- <script src="jquery/jquery.min.js"></script>
- <script src="bootstrap/js/bootstrap.min.js"></script>
- <script src="bootstrap-table/dist/bootstrap-table.min.js"></script>
- <script src="bootstrap-table/dist/locale/bootstrap-table-zh-CN.min.js"></script>
二:html页面标签内容
- <div class="panel panel-default">
- <div class="panel-heading">
- 查询条件
- </div>
- <div class="panel-body form-group" style="margin-bottom:0px;">
- <label class="col-sm-1 control-label" style="text-align: right; margin-top:5px">姓名:</label>
- <div class="col-sm-2">
- <input type="text" class="form-control" name="Name" id="search_name"/>
- </div>
- <label class="col-sm-1 control-label" style="text-align: right; margin-top:5px">手机号:</label>
- <div class="col-sm-2">
- <input type="text" class="form-control" name="Name" id="search_tel"/>
- </div>
- <div class="col-sm-1 col-sm-offset-4">
- <button class="btn btn-primary" id="search_btn">查询</button>
- </div>
- </div>
- </div>
- <table id="mytab" class="table table-hover"></table>
三:JS分页代码
- $('#mytab').bootstrapTable({
- method : 'get',
- url : "user/getUserListPage",//请求路径
- striped : true, //是否显示行间隔色
- pageNumber : 1, //初始化加载第一页
- pagination : true,//是否分页
- sidePagination : 'client',//server:服务器端分页|client:前端分页
- pageSize : 4,//单页记录数
- pageList : [ 5, 10, 20, 30 ],//可选择单页记录数
- showRefresh : true,//刷新按钮
- queryParams : function(params) {//上传服务器的参数
- var temp = {//如果是在服务器端实现分页,limit、offset这两个参数是必须的
- limit : params.limit, // 每页显示数量
- offset : params.offset, // SQL语句起始索引
- //page : (params.offset / params.limit) + 1, //当前页码
- Name : $('#search_name').val(),
- Tel : $('#search_tel').val()
- };
- return temp;
- },
- columns : [ {
- title : '登录名',
- field : 'loginName',
- sortable : true
- }, {
- title : '姓名',
- field : 'name',
- sortable : true
- }, {
- title : '手机号',
- field : 'tel',
- }, {
- title : '性别',
- field : 'sex',
- formatter : formatSex,//对返回的数据进行处理再显示
- }, {
- title : '操作',
- field : 'id',
- formatter : operation,//对资源进行操作
- } ]
- })
- //value代表该列的值,row代表当前对象
- function formatSex(value, row, index) {
- return value == 1 ? "男" : "女";
- //或者 return row.sex == 1 ? "男" : "女";
- }
- //删除、编辑操作
- function operation(value, row, index) {
- var htm = "<button>删除</button><button>修改</button>"
- return htm;
- }
- //查询按钮事件
- $('#search_btn').click(function() {
- $('#mytab').bootstrapTable('refresh', {
- url : 'user/getUserListPage'
- });
- })
四:bootstrap-table 实现前端分页
▶ 修改JS分页代码中某些属性
- sidePagination:'client',
- queryParams : function (params) {
- var temp = {
- name:$('#search_name').val(),
- tel:$('#search_tel').val()
- };
- return temp;
- },
▶ 定义user对象
- package com.debo.common;
- public class User {
- private Integer id;
- private String loginName;
- private String name;
- private String tel;
- private Integer sex;
- public Integer getId() {
- return id;
- }
- public void setId(Integer id) {
- this.id = id;
- }
- public String getLoginName() {
- return loginName;
- }
- public void setLoginName(String loginName) {
- this.loginName = loginName;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public String getTel() {
- return tel;
- }
- public void setTel(String tel) {
- this.tel = tel;
- }
- public Integer getSex() {
- return sex;
- }
- public void setSex(Integer sex) {
- this.sex = sex;
- }
- }
▶ 服务器Controller层代码
- /**
- *直接一次性查出所有的数据,返回给前端,bootstrap-table自行分页
- */
- @RequestMapping("/getUserListPage")
- @ResponseBody
- public List<User> getUserListPage(User user,HttpServletRequest request){
- List<User> list = userService.getUserListPage(user);
- return list;
- }
▶ mabatis语句
- <select id="getUserListPage" resultType="com.debo.common.User">
- SELECT * FROM user WHERE 1 = 1
- <if test="name!=null and name !=''">
- AND name LIKE CONCAT('%',#{name},'%')
- </if>
- <if test="tel!=null and tel !=''">
- AND tel = #{tel}
- </if>
- </select>
五:bootstrap-table 实现服务器端分页
▶ 设置JS分页代码中的某些属性
- sidePagination:'server',
- queryParams : function (params) {
- var temp = {
- limit : params.limit, // 每页显示数量
- offset : params.offset, // SQL语句起始索引
- page: (params.offset / params.limit) + 1, //当前页码
- Name:$('#search_name').val(),
- Tel:$('#search_tel').val()
- };
- return temp;
- },
▶ 封装公共的page对象,并让user对象继承page对象
- package com.debo.common;
- public class Page {
- //每页显示数量
- private int limit;
- //页码
- private int page;
- //sql语句起始索引
- private int offset;
- public int getLimit() {
- return limit;
- }
- public void setLimit(int limit) {
- this.limit = limit;
- }
- public int getPage() {
- return page;
- }
- public void setPage(int page) {
- this.page = page;
- }
- public int getOffset() {
- return offset;
- }
- public void setOffset(int offset) {
- this.offset = offset;
- }
- }
- package com.debo.common;
- public class User extends Page{
- private Integer id;
- private String loginName;
- private String name;
- private String tel;
- private Integer sex;
- public Integer getId() {
- return id;
- }
- public void setId(Integer id) {
- this.id = id;
- }
- public String getLoginName() {
- return loginName;
- }
- public void setLoginName(String loginName) {
- this.loginName = loginName;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public String getTel() {
- return tel;
- }
- public void setTel(String tel) {
- this.tel = tel;
- }
- public Integer getSex() {
- return sex;
- }
- public void setSex(Integer sex) {
- this.sex = sex;
- }
- }
▶ 封装返回数据实体类
- package com.debo.common;
- import java.util.ArrayList;
- import java.util.List;
- public class PageHelper<T> {
- //实体类集合
- private List<T> rows = new ArrayList<T>();
- //数据总条数
- private int total;
- public PageHelper() {
- super();
- }
- public List<T> getRows() {
- return rows;
- }
- public void setRows(List<T> rows) {
- this.rows = rows;
- }
- public int getTotal() {
- return total;
- }
- public void setTotal(int total) {
- this.total = total;
- }
- }
▶ 服务器Controller层代码
- @RequestMapping("/getUserListPage")
- @ResponseBody
- public PageHelper<User> getUserListPage(User user,HttpServletRequest request) {
- PageHelper<User> pageHelper = new PageHelper<User>();
- // 统计总记录数
- Integer total = userService.getTotal(user);
- pageHelper.setTotal(total);
- // 查询当前页实体对象
- List<User> list = userService.getUserListPage(user);
- pageHelper.setRows(list);
- return pageHelper;
- }
▶ mybatis语句
- <select id="getTotal" resultType="int">
- SELECT count(1) FROM user WHERE 1 = 1
- <if test="name!=null and name !=''">
- AND name LIKE CONCAT('%',#{name},'%')
- </if>
- <if test="tel!=null and tel !=''">
- AND tel = #{tel}
- </if>
- </select>
- <select id="getUserListPage" resultType="com.debo.common.User">
- SELECT * FROM user WHERE 1 = 1
- <if test="name!=null and name !=''">
- AND name LIKE CONCAT('%',#{name},'%')
- </if>
- <if test="tel!=null and tel !=''">
- AND tel = #{tel}
- </if>
- LIMIT #{offset},#{limit}
- </select>
tip:增、删、改操作后重新加载表格
$("#mytab").bootstrapTable('refresh', {url : url});
bootstrap table分页(前后端两种方式实现)的更多相关文章
- bootstrap-paginator分页插件的两种使用方式
分页有两种方式: 1. 前台分页:ajax一次请求获取全部数据,适合少量数据(万条数据以下): $.ajax({ type: "GET", url: "",// ...
- 斑马打印机客户端GET和POST,以及后端两种打印方式。
斑马打印机客户端GET和POST,以及后端两种打印方式. 背景环境:打印机安装在客户端外网.当用户登录时,通过ajax取服务器数据,返回打印机命令,然后客户端通过JS发送给斑马打印机. 1.使用Get ...
- easyUI之datagrid绑定后端返回数据的两种方式
先来看一下某一位大佬留下的easyUI的API对datagrid绑定数据的两种方式的介绍. 虽然精简,但是,很具有“师傅领进门,修行靠个人”的精神,先发自内心的赞一个. 但是,很多人和小编一样,第一次 ...
- 基于layPage分页插件浅析两种分页方式
最近在开发过程中经常用到分页,今天挤出些时间来捋一捋自己的经验 在web开发中,一般显示数据列表页时,我们会用到分页控件来显示数据.采用分页一般基于两种不同的需求,一种是数据量不算很大,但是在页面展示 ...
- Sql Server 聚集索引扫描 Scan Direction的两种方式------FORWARD 和 BACKWARD
最近发现一个分页查询存储过程中的的一个SQL语句,当聚集索引列的排序方式不同的时候,效率差别达到数十倍,让我感到非常吃惊 由此引发出来分页查询的情况下对大表做Clustered Scan的时候, 不同 ...
- Django学习——ajax发送其他请求、上传文件(ajax和form两种方式)、ajax上传json格式、 Django内置序列化(了解)、分页器的使用
1 ajax发送其他请求 1 写在form表单 submit和button会触发提交 <form action=""> </form> 注释 2 使用inp ...
- 在基于MVC的Web项目中使用Web API和直接连接两种方式混合式接入
在我之前介绍的混合式开发框架中,其界面是基于Winform的实现方式,后台使用Web API.WCF服务以及直接连接数据库的几种方式混合式接入,在Web项目中我们也可以采用这种方式实现混合式的接入方式 ...
- Log4Net日志记录两种方式
简介 log4net库是Apache log4j框架在Microsoft .NET平台的实现,是一个帮助程序员将日志信息输出到各种目标(控制台.文件.数据库等)的工具. log4net是Ap ...
- Json传递数据两种方式(json大全)
1.Json传递数据两种方式(json大全)----------------------------字符串 var list1 = ["number","name&quo ...
随机推荐
- android混合动画实现
在android开发,我们会常常使用到动画,可是简单的一种动画(如旋转.缩放.渐变.位移等)有时候并不能满足我们项目的要求,这时候就须要运用到混合动画.那么在安卓中是怎样实现一个炫酷的混合动画,以下是 ...
- Android开发之ListView实现不同品种分类分隔栏的效果(非ExpandableListView实现)
我们有时候会遇到这么一个情况.就是我在一个ListView里面须要显示的东西事实上是有种类之分的.比方我要分冬天,夏天.秋天.春天,然后在这每一个季节以下再去载入各自的条目数据. 还有,比方我们的通讯 ...
- Android离线语音识别(PocketSphinx)
近期做项目.用到离线语音识别.整了好久,查了好多方法.最终完毕.网上资料有点乱,并且大部分就是那几个人写的.一群人转!以下我总结一下.也为后来人行个方便. 关于环境配置我就不多说了.我就是依照这个教程 ...
- GitHub 高速上手 ---- 创建密钥,连接
首先要在GitHub上创建一个帐号,因为本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以要在本地生成一个私钥和一个密钥 命令,后面跟的邮箱.要跟你自己的:增加输出的位置:能够不用设置 ...
- c++编译常见错误原因集中
1 c++ compiler error c4430 "c++ doesn't support default int" 1.1 可能的原因之一 我用了在一个头文件中定义的宏,但是 ...
- [Sqlite]-->数据迁移备份--从低版本号3.6.2到高版本号3.8.6
引子: 1. Sqlite在Windows.Linux 和 Mac OS X 上的安装过程 2.嵌入式数据库的安装.建库.建表.更新表结构以及数据导入导出等等具体过程记录 个字段IPHONE和LOGI ...
- sed 之 模式空间 & 保持空间
模式空间:容纳当前输入行的缓冲区: 保持空间:作为辅助的一个缓冲区,可以和模式空间进行交互,但是命令不能直接作用于保持空间. 由上面定义可以知道,模式空间和保持空间是两个独立的缓冲区,可以进行交互,命 ...
- jsp整合discuz
转自:http://blog.sina.com.cn/s/blog_49298ed001000a99.html 最近在实验室做项目用到的一个东西,拿来介绍一下. 需求:现有行业应用 ...
- AirtestIDE详解(跨平台的UI自动化编辑器)
Airtest 是网易出品的一款基于图像识别和poco控件识别的一款UI自动化测试工具. AirtestIDE 是一个跨平台.多端(Windows.web.android.ios.游戏)的UI自动化测 ...
- 对于Mobile模块化的概念认知(小白)
最近刚刚学习了Mobile的一些基础知识,把它整理一下方便自己的学习 那什么是Mobile呢? 自己的理解是将一个项目中共同的部分抽出来,这样就形成了Mobile模块. 为什么要使用Mobile呢? ...