实现bootstrap table服务端实现分页demo,具体内容如下

首页index.html
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Demo</title>
<link rel="stylesheet" href="/assets/css/bootstrap.min.css" rel="external nofollow" />
<link rel="stylesheet" href="/assets/css/bootstrap-table.min.css" rel="external nofollow" >
<script src="/assets/js/jquery-2.1.1.min.js"></script>
<script src="/assets/js/bootstrap.min.js"></script>
<script src="/assets/js/bootstrap-table.min.js"></script>
<script src="/assets/js/bootstrap-table-zh-CN.min.js"></script>
<script src="/assets/js/index.js"></script>
</head>
<body>
<!--查询窗体-->
<div class="widget-content">
<form method="post" class="form-horizontal" id="eventqueryform">
<input type="text" class="span2" name="seqNo" placeholder="编号">
<input type="text" class="span3" name="name" placeholder="姓名">
<input type="button" class="btn btn-default span1" id="eventquery" value="查询">
</form>
</div>
<div class="widget-content">
<!--工具条-->
<div id="toolbar">
<button class="btn btn-success btn-xs" data-toggle="modal" data-target="#add">添加事件</button>
</div>
<table id="eventTable"></table>
</div>
</body>
</html>
index.js
$(function() {
// 初始化表格
initTable();
// 搜索按钮触发事件
$("#eventquery").click(function() {
$('#eventTable').bootstrapTable(('refresh')); // 很重要的一步,刷新url!
// console.log("/program/area/findbyItem?offset="+0+"&"+$("#areaform").serialize())
$('#eventqueryform input[name=\'name\']').val('')
$('#eventqueryform input[name=\'seqNo\']').val('')
});
});
// 表格初始化
function initTable() {
$('#eventTable').bootstrapTable({
method : 'post', // 向服务器请求方式
contentType : "application/x-www-form-urlencoded", // 如果是post必须定义
url : '/bootstrap_table_demo/findbyitem', // 请求url
cache : false, // 是否使用缓存,默认为true,所以一般情况下需要设置一下这个属性(*)
striped : true, // 隔行变色
dataType : "json", // 数据类型
pagination : true, // 是否启用分页
showPaginationSwitch : false, // 是否显示 数据条数选择框
pageSize : 10, // 每页的记录行数(*)
pageNumber : 1, // table初始化时显示的页数
pageList: [5, 10, 15, 20], //可供选择的每页的行数(*)
search : false, // 不显示 搜索框
sidePagination : 'server', // 服务端分页
classes : 'table table-bordered', // Class样式
// showRefresh : true, // 显示刷新按钮
silent : true, // 必须设置刷新事件
toolbar : '#toolbar', // 工具栏ID
toolbarAlign : 'right', // 工具栏对齐方式
queryParams : queryParams, // 请求参数,这个关系到后续用到的异步刷新
columns : [ {
field : 'seqNo',
title : '编号',
align : 'center'
}, {
field : 'name',
title : '姓名',
align : 'center'
}, {
field : 'sex',
title : '性别',
align : 'center'
}, {
field : 'id',
title : '操作',
align : 'center',
width : '280px',
formatter : function(value, row, index) {
// console.log(JSON.stringify(row));
}
} ],
});
}
// 分页查询参数,是以键值对的形式设置的
function queryParams(params) {
return {
name : $('#eventqueryform input[name=\'name\']').val(), // 请求时向服务端传递的参数
seqNo : $('#eventqueryform input[name=\'seqNo\']').val(),
limit : params.limit, // 每页显示数量
offset : params.offset, // SQL语句偏移量
}
}
服务端 servlet
/**
* Servlet实现类
*/
public class UserFindByItemSetvlet extends HttpServlet {
private static final long serialVersionUID = 1L;
private IUserService service = new UserServiceImpl();
public UserFindByItemSetvlet() {
super();
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request, response);
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
response.setContentType("text/json; charset=UTF-8");
// 得到表单数据
int offset = Integer.parseInt(request.getParameter("offset").trim());
int limit = Integer.parseInt(request.getParameter("limit").trim());
String seqNo = request.getParameter("seqNo").trim();
String name = request.getParameter("name").trim();
// 调用业务组件,得到结果
PageBean<UserBean> pageBean;
try {
pageBean = service.findByItem(offset, limit, seqNo, name);
ObjectMapper oMapper = new ObjectMapper();
//对象转换为json数据 ,且返回
oMapper.writeValue(response.getWriter(), pageBean);
} catch (Exception e) {
e.printStackTrace();
}
}
}
分页封装类
/**
* 分页实体类
*/
public class PageBean<T> {
/** 行实体类 */
private List<T> rows = new ArrayList<T>();
/** 总条数 */
private int total;
public PageBean() {
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;
}
}
获取用户实现类
public class UserServiceImpl implements IUserService{
/**
* sql查询语句
*/
public PageBean<UserBean> findByItem(int offset, int limit, String seqNo, String name) {
PageBean<UserBean> cutBean = new PageBean<UserBean>();
// 基本SQL语句
String sql = "SELECT * FROM c_userinfo where 1=1 ";
// 动态条件的SQL语句
String itemSql = "";
if (seqNo != null && seqNo.length() != 0) {
itemSql += "and SeqNo like '%" + seqNo + "%' ";
}
if (name != null && name.length() != 0) {
itemSql += "and Name like '%" + name + "%' ";
}
// 获取sql连接
Connection con = DButil.connect();
PreparedStatement ps = null;
ResultSet rs = null;
try {
ps = con.prepareStatement(sql + itemSql + "limit ?,?");
ps.setInt(1, offset);
ps.setInt(2, limit);
rs = ps.executeQuery();
while (rs.next()) {
UserBean bean = new UserBean();
bean.setSeqNo(rs.getInt("seqNo"));
bean.setName(rs.getString("name"));
bean.setSex(rs.getInt("sex"));
bean.setBirth(rs.getString("birth"));
cutBean.getRows().add(bean);
}
// 得到总记录数,注意,也需要添加动态条件
ps = con.prepareStatement("SELECT count(*) as c FROM c_userinfo where 1=1 " + itemSql);
rs = ps.executeQuery();
if (rs.next()) {
cutBean.setTotal(rs.getInt("c"));
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
DButil.close(con);
if (ps != null) {
try {
ps.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if (rs != null) {
try {
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
return cutBean;
}
}
数据库工具类
/**
* 数据库工具类
*
* @author way
*
*/
public class DButil {
/**
* 连接数据库
*
*/
public static Connection connect() {
Properties pro = new Properties();
String driver = null;
String url = null;
String username = null;
String password = null;
try {
InputStream is = DButil.class.getClassLoader()
.getResourceAsStream("DB.properties");
pro.load(is);
driver = pro.getProperty("driver");
url = pro.getProperty("url");
username = pro.getProperty("username");
password = pro.getProperty("password");
Class.forName(driver);
Connection conn = DriverManager.getConnection(url, username,
password);
return conn;
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
return null;
}
/**
* 关闭数据库
*
* @param conn
*
*/
public static void close(Connection con) {
if (con != null) {
try {
con.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
DB.properties文件
driver=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/gov_social?useUnicode\=true&characterEncoding\=utf-8 username=root password=root
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# bootstrap
# table
# 分页
# bootstrap table 服务器端分页例子分享
# 第一次动手实现bootstrap table分页效果
# Bootstrap table分页问题汇总
# BootStrap Table 分页后重新搜索问题的解决办法
# Bootstrap table两种分页示例
# BootStrap中Table分页插件使用详解
# 基于SpringMVC+Bootstrap+DataTables实现表格服务端分页、模糊查询
# Bootstrap Table服务器分页与在线编辑应用总结
# 解决JS组件bootstrap table分页实现过程中遇到的问题
# bootstrap table分页模板和获取表中的ID方法
# 服务端
# 每页
# 条数
# 行数
# 很重要
# 实体类
# 关系到
# 表单
# 首页
# 转换为
# 具体内容
# 工具条
# 大家多多
# 键值
# 可供选择
# 默认为
# 连接数据库
# 偏移量
# refresh
相关文章:
如何自定义建站之星网站的导航菜单样式?
小说建站VPS选用指南:性能对比、配置优化与建站方案解析
网站插件制作软件免费下载,网页视频怎么下到本地插件?
哈尔滨网站建设策划,哈尔滨电工证查询网站?
如何选择最佳自助建站系统?快速指南解析优劣
如何访问已购建站主机并解决登录问题?
免费网站制作appp,免费制作app哪个平台好?
如何用西部建站助手快速创建专业网站?
建站之星Pro快速搭建教程:模板选择与功能配置指南
微信网站制作公司有哪些,民生银行办理公司开户怎么在微信网页上查询进度?
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
如何快速上传建站程序避免常见错误?
建站主机服务器选购指南:轻量应用与VPS配置解析
c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】
如何正确下载安装西数主机建站助手?
建站之星3.0如何解决常见操作问题?
C#如何序列化对象为XML XmlSerializer用法
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
如何获取免费开源的自助建站系统源码?
如何配置FTP站点权限与安全设置?
常州企业网站制作公司,全国继续教育网怎么登录?
如何确认建站备案号应放置的具体位置?
网站设计制作公司地址,网站建设比较好的公司都有哪些?
如何快速登录WAP自助建站平台?
制作网站的软件免费下载,免费制作app哪个平台好?
Swift中循环语句中的转移语句 break 和 continue
Android使用GridView实现日历的简单功能
怀化网站制作公司,怀化新生儿上户网上办理流程?
如何快速打造个性化非模板自助建站?
如何快速查询网站的真实建站时间?
Android自定义控件实现温度旋转按钮效果
Bpmn 2.0的XML文件怎么画流程图
广州建站公司哪家好?十大优质服务商推荐
c++怎么用jemalloc c++替换默认内存分配器【性能】
图册素材网站设计制作软件,图册的导出方式有几种?
教程网站设计制作软件,怎么创建自己的一个网站?
实惠建站价格推荐:2025年高性价比自助建站套餐解析
如何快速生成橙子建站落地页链接?
沈阳制作网站公司排名,沈阳装饰协会官方网站?
青岛网站建设如何选择本地服务器?
C#怎么使用委托和事件 C# delegate与event编程方法
建站之星CMS五站合一模板配置与SEO优化指南
C++如何使用std::optional?(处理可选值)
番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?
制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
建站之星安装模板失败:服务器环境不兼容?
如何通过虚拟主机快速搭建个人网站?
已有域名建站全流程解析:网站搭建步骤与建站工具选择
c++ stringstream用法详解_c++字符串与数字转换利器
*请认真填写需求信息,我们会在24小时内与您取得联系。