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的时候, 不同 ...
-
在基于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 ...
-
ASP.NET Web API接受AngualrJS的QueryString的两种方式
ASP.NET Web API如何接受来自AngualrJS的QueryString呢?本篇体验两种方式. 第一种方式:http://localhost:49705/api/products?sear ...
随机推荐
-
二路归并排序算法实现-完整C语言程序
/*********************************************************************************************** 1.设 ...
-
WPF之依赖属性
Introduction When you begin to develop appliations with WPF, you will soon stumble across Dependency ...
-
构建之法 第6~7章读后感和对Scrum的理解
第六章-敏捷流程 第六章主要详细介绍了敏捷流程,在软件工程范畴里,“敏捷流程”是一系列价值观和方法论的集合.这一章以敏捷流程的Scrum方法论而展开,而敏捷流程的精髓就是在于快速的交付. 敏捷开发的流 ...
-
uestc1888 Birthday Party 组合数学,乘法原理
题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=25539#problem/G 题目意思: 有n个人,每个人有一个礼物,每个人能拿 ...
-
NPOI的测试代码
NPOI\testcases\main\testcases vs10.csproj 需要注意,重新引用一下NPOI类库 需要注意的是,测试项目,使用了NUnit 找到测试项目下的SS文件夹,再定位到U ...
-
c# 无损高质量压缩图片代码
/// <summary> /// 无损压缩图片 /// </summary> /// <param name="sFile">原图片</ ...
-
Android开发全套视频教程在线观看网盘下载
千锋金牌讲师老罗老师简介: 国内第一批Android教学讲师,10多年软件开发经验,6年多教学经验,曾担任广东电信北京分公司移动事业部项目经理,主持过微软中国平台考试系统.山西省旅游局智能化平台等大型 ...
-
Cortex-A9 PWM Timer
PWM定时器 4412时钟为我们提供了PWM定时器,在4412*有5个32位的定时器,这些定时器可发送中断信号给ARM子系统.另外,定时器0.1.2.3包含了脉冲宽度调制(PWM),并 ...
-
【干货】.NET开发通用组件发布(三) 简易数据采集组件
组件介绍和合作开发 http://www.cnblogs.com/MrHuo/p/MrHuoControls.html 简易数据采集组件 怎么说他是一个简易的数据采集组件呢?因为由于时间仓促,缺少从某 ...
-
Educational Codeforces Round 63 (Rated for Div. 2) C. Alarm Clocks Everywhere gcd
题意:给出一个递增的时间序列a 给出另外一个序列b (都是整数) 以b中任选一个数字作为间隔 自己从1开始任选一个时间当成开始时间 输出选择的数字标号以及 开始时间 思路 直接求间隔的公共gc ...