Bootstrap中实现table分页怎么做,有几种方式
导读:关于“Bootstrap中实现table分页怎么做,有几种方式”的知识点有一些人不是很理解,对此小编给大家总结了相关内容,文中的内容简单清晰,易于学习与理解,具有一定的参考学习价值,希望能对大家有所帮助,接下来就跟随小编一起学习一下“Boo...
关于“Bootstrap中实现table分页怎么做,有几种方式”的知识点有一些人不是很理解,对此小编给大家总结了相关内容,文中的内容简单清晰,易于学习与理解,具有一定的参考学习价值,希望能对大家有所帮助,接下来就跟随小编一起学习一下“Bootstrap中实现table分页怎么做,有几种方式”吧。bootstrap table分页的两种方式:
前端分页:一次性从数据库查询所有的数据,在前端进行分页(数据量小的时候或者逻辑处理不复杂的话可以使用前端分页)
服务器分页:每次只查询当前页面加载所需要的那几条数据
bootstrap 下载地址:http://www.bootcss.com/
bootstrap-table 下载地址:http://bootstrap-table.wenzhixin.net.cn/
jquery下载地址:http://www.jq22.com/jquery-info122
分页效果(请忽略样式)
一:准备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;
//省略Get/Set函数
}
▶ 服务器Controller层代码
/**
*直接一次性查出所有的数据,返回给前端,bootstrap-table自行分页
*/
@RequestMapping("/getUserListPage")
@ResponseBody
public ListUser>
getUserListPage(User user,HttpServletRequest request){
ListUser>
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 PageHelperT>
{
//实体类集合
private ListT>
rows = new ArrayListT>
();
//数据总条数
private int total;
public PageHelper() {
super();
}
public ListT>
getRows() {
return rows;
}
public void setRows(ListT>
rows) {
this.rows = rows;
}
public int getTotal() {
return total;
}
public void setTotal(int total) {
this.total = total;
}
}
▶ 服务器Controller层代码
@RequestMapping("/getUserListPage")
@ResponseBody
public PageHelperUser>
getUserListPage(User user,HttpServletRequest request) {
PageHelperUser>
pageHelper = new PageHelperUser>
();
// 统计总记录数
Integer total = userService.getTotal(user);
pageHelper.setTotal(total);
// 查询当前页实体对象
ListUser>
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分页怎么做,有几种方式”的相关知识,感谢各位的阅读,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注网络,小编每天都会为大家更新不同的知识。
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: Bootstrap中实现table分页怎么做,有几种方式
本文地址: https://pptw.com/jishu/654282.html
