原文連接:http://blog.csdn.net/qq_37936542/article/details/79163125css
bootstrap table分頁有那種方式:html
前端分頁:一次性從數據庫查詢全部的數據,在前端進行分頁(數據量小的時候或者邏輯處理不復雜的話能夠使用前端分頁)前端
服務器分頁:每次只查詢當前頁面加載所須要的那幾條數據java
一:引入js、css文件jquery
-
- <link href="../css/bootstrap.min.css" rel="stylesheet" />
- <link href="../css/bootstrap-table.min.css" rel="stylesheet">
-
- <script src="../js/jquery.min.js"></script>
- <script src="../js/bootstrap.min.js"></script>
- <script src="../js/bootstrap-table.min.js"></script>
- <script src="../js/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>
- <div id="toolbar" class="btn-group pull-right" style="margin-right: 20px;">
- <button id="btn_edit" type="button" class="btn btn-default" style="display: none; border-radius: 0">
- <span class="glyphicon glyphicon-pencil" aria-hidden="true" ></span>修改
- </button>
- <button id="btn_delete" type="button" class="btn btn-default" style="display: none;">
- <span class="glyphicon glyphicon-remove" aria-hidden="true"></span>刪除
- </button>
- <button id="btn_add" type="button" class="btn btn-default">
- <span class="glyphicon glyphicon-plus" aria-hidden="true"></span>新增
- </button>
- </div>
三:js代碼
- $('#mytab').bootstrapTable({
- method: 'post',
- contentType: "application/x-www-form-urlencoded",//當請求方法爲post的時候,必需要有!!!!
- url:ROOT+"user/getUserListPage",//請求路徑
- striped: true, //是否顯示行間隔色
- pageNumber: 1, //初始化加載第一頁
- pagination:true,//是否分頁
- sidePagination:'server',//server:服務器端分頁|client:前端分頁
- pageSize:10,//單頁記錄數
- 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,//對返回的數據進行處理再顯示
- }
- ]
- })
-
- //value表明該列的值,row表明當前對象
- function formatSex(value,row,index){
- return value == 1 ? "男" : "女";
- //或者 return row.sex == 1 ? "男" : "女";
- }
-
- //查詢按鈕事件
- $('#search_btn').click(function(){
- $('#mytab').bootstrapTable('refresh', {url: ROOT+'user/getUserListPage'});
- })
四:實現前端分頁sql
(一)設置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;
- }
- }
(三)服務器端代碼
- /**
- *直接一次性查出全部的數據,返回給前臺
- */
- @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>
五:實現服務器端分頁編程
(一)設置js中參數bootstrap
- 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;
- }
-
- }
(四)服務器代碼
- @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 #{offect},#{limit}
- </select>
前端頁面代碼參考文章:點擊打開連接小程序
文末福利:
福利一:前端,Java,產品經理,微信小程序,Python等8G資源合集大放送:https://www.jianshu.com/p/e8197d4d9880
福利二:微信小程序入門與實戰全套詳細視頻教程
領取方式:
若是須要學習視頻,歡迎關注 【編程微刊】微信公衆號,回覆【領取資源】一鍵領取如下全部乾貨資源,獲取更多有用技術乾貨、文檔資料。全部文檔會持續更新,歡迎關注一塊兒成長!