1. 程式人生 > 程式設計 >bootstrap Table的使用方法總結

bootstrap Table的使用方法總結

本文為大家分享了bootstrap Table的使用方法,供大家參考,具體內容如下

官網資料

效果圖:

bootstrap Table的使用方法總結

案例:

html

<!-- 表格 -->
<table id="ffServerSystemCheckListTable"
       data-toolbar="#toolbar"
       data-show-columns="true"
       data-show-columns-toggle-all="true">
 
<%--     <thead>--%>
<%--     <tr>--%>
<%--          <th data-field="cityName">ID</th>--%>
<%--          <th data-field="cityName">Item Name</th>--%>
<%--          <th data-field="cityName">Item Price</th>--%>
<%--     </tr>--%>
<%--     </thead>--%>

</table>

javascript

$(document).ready(function () {
 
    //表格外掛
    mytable=$('#ffServerSystemCheckListTable').bootstrapTable({
 
        //請求方法
        method: 'post',//型別json
        dataType: "json",contentType: "application/x-www-form-urlencoded",//顯示檢索按鈕
        //showSearch: false,//顯示重新整理按鈕
        showRefresh: false,//顯示切換手機試圖按鈕
        showToggle: false,//顯示 內容列下拉框
        showColumns: false,//顯示到處按鈕
        showExport: false,//顯示切換分頁按鈕
        showPaginationSwitch: false,//最低顯示2行
        minimumCountColumns: 2,//是否顯示行間隔色
        //striped: true,//是否使用快取,預設為true,所以一般情況下需要設定一下這個屬性(*)
        cache: false,//是否顯示分頁(*)
        pagination: true,//排序方式
        sortOrder: "asc",//初始化載入第一頁,預設第一頁
        pageNumber: 1,//每頁的記錄行數(*)
        pageSize: 10,//可供選擇的每頁的行數(*)
        pageList: [10,25,50,100],//這個介面需要處理bootstrap table傳遞的固定引數,並返回特定格式的json資料
        url: "${ctx}/ff/server/ffServerSystemCheck/data",//預設值為 'limit',傳給服務端的引數為:limit,offset,search,sort,order Else
        //queryParamsType:'',查詢引數,每次呼叫是會帶上這個引數,可自定義
        queryParams: function (params) {
            var searchParam = $("#searchForm").serializeJSON();
            searchParam.pageNo = params.limit === undefined ? "1" : params.offset / params.limit + 1;
            searchParam.pageSize = params.limit === undefined ? -1 : params.limit;
            searchParam.orderBy = params.sort === undefined ? "" : params.sort + " " + params.order;
            return searchParam;
        },//分頁方式:client客戶端分頁,server服務端分頁(*)
        sidePagination: "server",// contextMenuTrigger:"right",//pc端 按右鍵彈出選單
        // contextMenuTriggerMobile: "press",//手機端 彈出選單,click:單擊, press:長按。
        // contextMenu: '#context-menu',onClickRow: function (row,$el) {
            rowId = row.id;
        },onShowSearch: function () {
            $("#search-collapse").slideToggle();
        },responseHandler: function (res) {//用於接收其他引數
            return res;
        },onPreBody: function (res) {},onLoadSuccess: function() {},onPostHeader: function () {},onAll: function () {},columns: [
            [
                {
                    field: 'cityName',title: '城市公司',rowspan: 2,formatter: function (value,row,index) {
                        return value;
 
                    }
                },{
                field: 'projectName',title: '專案名稱',rowspan: 2
            },{
                title: '首頁輪播',colspan: 2,align: 'center'
            },{
                title: '訊息',{
                title: '海報模板',{
                title: '樓盤動態',{
                title: '專案賣點',{
                title: '專案海報',{
                title: '專案視訊',align: 'center'
            }],[{
                field: 'newsCount',title: '更新次數',},{
                field: 'newsState',title:"-",class:'newsTitle',index) {
                    if (value=='不合格') {
                        return "<span style=\"color: red;\">不合格<span>";
                    }
                    return value;
                    // return jp.getDictLabel(${fns:toJson(fns:getDictList('cooperation_flag'))},value,"-");
                }
 
            },{
                field: 'msgCount',title: '更新次數'
            },{
                field: 'msgState',title: '-',class:'msgTitle',index) {
                    if (value=='不合格') {
                        return "<span style=\"color: red;\">不合格<span>";
                    }
                    return value;
                }
 
            },{
                field: 'tempCount',{
                field: 'tempState',class:'tempTitle',{
                    field: 'houseCount',title: '更新次數'
                },{
                field: 'houseState',class:'houseTitle',{
                    field: 'sellCount',title: '更新次數'
 
                },{
                field: 'sellState',class:'sellTitle',{
                    field: 'postCount',{
                field: 'postState',class:'postTitle',{
                field: 'videoCount',eCaKpQeA
title: '更新次數' },{ field: 'videoState',class:'videoTitle',index) { if (value=='不合格') { return "<span style=\"color: red;\">不合格<span>"; } return value; } } ] ] }); if (navigator.userAgent.match(/(iPhone|iPod|
android
|ios)/i)) {//如果是移動端 $('#ffServerSystemCheckListTable').bootstrapTable("toggleView"); } $('#ffServerSystemCheckListTable').on('check.bs.table uncheck.bs.table load-success.bs.table ' + 'check-all.bs.table uncheck-all.bs.table',function () { $('#remove').prop('disabled',!$('#ffServerSystemCheckListTable').bootstrapTable('getSelections').length); $('#batchSet').prop('disabled',!$('#ffServerSystemCheckListTable').bootstrapTable('getSelections').length); $('#view,#edit').prop('disabled',$('#ffServerSystemCheckListTable').bootstrapTable('getSelections').length != 1); }); // 繫結查詢按扭 $("#search").click("click",function () { //重新載入表格引數 // $('#ffServerSystemCheckListTable').bootstrapTable("refreshOptions",{ // //url : path + "/api/peopledataInfo/getPeopleInfoList",// 獲取資料的地址 // columns : [],// // }); //動態表頭設定 $.ajax({ url: "${ctx}/ff/server/ffServerSystemCheck/checkInfo",// type : "POST",data: $("#searchForm").serialize(),success: function (data) { $(".newsTitle .th-inner").html(data.newsTitle); $(".msgTitle .th-inner").html(data.msgTitle); $(".tempTitle .th-inner").html(data.tempTitle); $(".houseTitle .th-inner").html(data.houseTitle); $(".sellTitle .th-inner").html(data.sellTitle); $(".postTitle .th-inner").html(data.postTitle); $(".videoTitle .th-inner").html(data.videoTitle); $('#ffServerSystemCheckListTable').bootstrapTable('refresh'); } }); }); });

java

controller:

@ResponseBody
@RequestMapping(value = "data")
public Map<String,Object> data(HttpServletRequest request,HttpServletResponse response) {
        Page<FfServerSystemCheck> page = server.findWebPage(new Page<FfServerSystemCheck>(request,response));
        Map<String,Object> map = new HashMap<String,Object>();
  map.put("rows",page.getList());
  map.put("total",page.getCount());
        return data;
    }

xml:

<select id="findWebList" resultType="com.jeeplus.modules.ff.server.entity.FfServerSystemCheck">
        <if test="dateTypeAll == '0'.toString() or dateTypeAll == '1'.toString() or dateTypeAll=='yesterday' or dateTypeAeCaKpQeAll=='today'">
            select
            cityName,projectName,newsCount,'-' newsState,msgCount,'-' msgState,tempCount,'-' tempState,houseCount,'-' houseState,sellCount,'-' sellState,postCount,'-' postState,videoCount,'-' videoState
        </if>
 
        <if test="dateTypeAll == 'http://www.cppcns.comweeks' or dateTypeAll == 'month' or dateTypeAll=='halfYear' or dateTypeAll=='years'">
            select
            cityName,CASE  WHEN newsCount > #{newsNum} THEN '合格'  ELSE '不合格' END newsState,CASE  WHEN msgCount >  #{msgNum} THEN '合格' ELSE '不合格' END msgState,CASE  WHEN tempCount >  #{tempNum} THEN '合格' ELSE '不合格' END tempState,CASE  WHEN houseCount > #{houseNum} THEN '合格' ELSE '不合格' END houseState,CASE  WHEN sellCount > #{sellNum} THEN '合格' ELSE '不合格' END sellState,CASE  WHEN postCount > #{postNum} THEN '合格' ELSE '不合格' END postState,CASE  WHEN videoCount > #{videoNum} THEN '合格' ELSE '不合格' END videoState
        </if>
 
 
        from (
        SELECT
        so.NAME cityName,pm.project_name projectName,( SELECT count(*) FROM ff_server_news_manage WHERE project_id = pm.id
        <if test="startDate != null and startDate != ''">
    AND DATE_FORMAT(pm.create_date,'%Y-%m-%d') <![CDATA[>=]]>  #{startDate}
   </if>
        <if test="endDate != null and endDate != ''">
    AND DATE_FORMAT(pm.create_date,'%Y-%m-%d') <![CDATA[<=]]>  #{endDate}
   </if>
        ) newsCount,( SELECT count(*) FROM ff_server_message_manage WHERE project_id = pm.id
        <if test="startDate != null and startDate != ''">
    AND DATE_FORMAT(pm.create_date,'%Y-%m-%d') <![CDATA[<=]]>  #{endDate}
   </if>
        ) msgCount,( SELECT count(*) FROM ff_tuoke_poster_template WHERE project_id = pm.id
        <if test="startDate != null and startDate != ''">
    AND DATE_FORMAT(pm.create_date,'%Y-%m-%d') <![CDATA[<=]]>  #{endDate}
   </if>
        ) tempCount,( SELECT count(*) FROM ff_server_houses_dynamic WHERE project_id = pm.id
        <if test="startDate != null and startDate != ''">
    AND DATE_FORMAT(pm.create_date,'%Y-%m-%d') <![CDATA[<=]]>  #{endDate}
   </if>
        ) houseCount,( SELECT count( CASE WHEN type = 0 THEN 1 END ) FROM ff_server_talk_tool WHERE project_id = pm.id
        <if test="startDate != null and startDate != ''">
    AND DATE_FORMAT(pm.create_date,'%Y-%m-%d') <![CDATA[<=]]>  #{endDate}
   </if>
        ) sellCount,( SELECT count( CASE WHEN type = 1 THEN 1 END ) FROM ff_server_talk_tool WHERE project_id = pm.id
        <if test="startDate != null and startDate != ''">
    AND DATE_FORMAT(pm.create_date,'%Y-%m-%d') <![CDATA[<=]]>  #{endDate}
   </if>
        ) postCount,( SELECT count( CASE WHEN type = 2 THEN 1 END ) FROM ff_server_talk_tool WHERE project_id = pm.id
        <if test="startDate != null and startDate != ''">
    AND DATE_FORMAT(pm.create_date,'%Y-%m-%d') <![CDATA[<=]]>  #{endDate}
   </if>
        ) videoCount
        FROM
        sys_office so
        INNER JOIN ff_server_project_manage pm ON pm.city_company = so.id
        <where>
            ${dataScope}
            <if test="cityCompanyId != null and cityCompanyId != ''">
    AND so.id = #{cityCompanyId}
   </if>
        </where>
        GROUP BY
        pm.project_name
        ORDER BY pm.create_date DESC
        ) as a
</select>

Page物件

/**
 * Copyright &copy; 2015-2020 <a href="http://www.jeeplus.org/" rel="external nofollow" >JeePlus</a> All rights reserved.
 */
package com.jeeplus.core.persistence;
 
import java.util.ArrayList;
import java.util.List;
import java.util.regex.Pattern;
 
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
 
import org.apache.commons.lang3.StringUtils;
 
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.jeeplus.common.config.Global;
import com.jeeplus.common.utils.CookieUtils;
 
/**
 * 分頁類
 * @author jeeplus
 * @version 2016-7-2
 * @param <T>
 */
public class Page<T> {
 
 protected int pageNo = 1; // 當前頁碼
 protected int pageSize = Integer.valueOf(Global.getConfig("page.pageSize")); // 頁面大小,設定為“-1”表示不進行分頁(分頁無效)
 
 protected long count;// 總記錄數,設定為“-1”表示不查詢總數
 
 protected int first;// 首頁索引
 protected int last;// 尾頁索引
 protected int prev;// 上一頁索引
 protected int next;// 下一頁索引
 
 private boolean firstPage;//是否是第一頁
 private boolean lastPage;//是否是最後一頁
 
 protected int length = 8;// 顯示頁面長度
 protected int slider = 1;// 前後顯示頁面長度
 
 private List<T> list = new ArrayList<T>();
 
 private String orderBy = ""; // 標準查詢有效, 例項: updatedate desc,name asc
 
 protected String funcName = "page"; // 設定點選頁碼呼叫的js函式名稱,預設為page,在一頁有多個分頁物件時使用。
 
 protected String funcParam = ""; // 函式的附加引數,第三個引數值。
 
 private String message = ""; // 設定提示訊息,顯示在“共n條”之後
 
 public Page() {
  this.pageSize = -1;
 }
 
 /**
  * 構造方法
  * @param request 傳遞 repage 引數,來記住頁碼
  * @param response 用於設定 Cookie,記住頁碼
  */
 public Page(HttpServletRequest request,HttpServletResponse response){
  this(request,response,-2);
 }
 
 /**
  * 構造方法
  * @param request 傳遞 repage 引數,來記住頁碼
  * @param response 用於設定 Cookie,記住頁碼
  * @param defaultPageSize 預設分頁大小,如果傳遞 -1 則為不分頁,返回所有資料
  */
 public Page(HttpServletRequest request,HttpServletResponse response,int defaultPageSize){
  // 設定頁碼引數(傳遞repage引數,來記住頁碼)
  String no = request.getParameter("pageNo");
  if (StringUtils.isNumeric(no)){
   CookieUtils.setCookie(response,"pageNo",no);
   this.setPageNo(Integer.parseInt(no));
  }else if (request.getParameter("repage")!=null){
   no = CookieUtils.getCookie(request,"pageNo");
   if (StringUtils.isNumeric(no)){
    this.setPageNo(Integer.parseInt(no));
   }
  }
  // 設定頁面大小引數(傳遞repage引數,來記住頁碼大小)
  String size = request.getParameter("pageSize");
  if (StringUtils.isNumeric(size)){
   CookieUtils.setCookie(response,"pageSize",size);
   this.setPageSize(Integer.parseInt(size));
  }else if (request.getParameter("repage")!=null){
   no = CookieUtils.getCookie(request,"pageSize");
   if (StringUtils.isNumeric(size)){
    this.setPageSize(Integer.parseInt(size));
   }
  }else if (defaultPageSize != -2){
   this.pageSize = defaultPageSize;
  }else if ("-1".equals(size)){
   this.pageSize = -1;
  }
  // 設定排序引數
  String orderBy = request.getParameter("orderBy");
  if (StringUtils.isNotBlank(orderBy)){
   this.setOrderBy(orderBy);
  }
 }
 
 /**
  * 構造方法
  * @param pageNo 當前頁碼
  * @param pageSize 分頁大小
  */
 public Page(int pageNo,int pageSize) {
  this(pageNo,pageSize,0);
 }
 
 /**
  * 構造方法
  * @param pageNo 當前頁碼
  * @param pageSize 分頁大小
  * @param count 資料條數
  */
 public Page(int pageNo,int pageSize,long count) {
  this(pageNo,count,new ArrayList<T>());
 }
 
 /**
  * 構造方法
  * @param pageNo 當前頁碼
  * @param pageSize 分頁大小
  * @param count 資料條數
  * @param list 本頁資料物件列表
  */
 public Page(int pageNo,long count,List<T> list) {
  this.setCount(count);
  this.setPageNo(pageNo);
  this.pageSize = pageSize;
  this.list = list;
 }
 
 /**
  * 初始化引數
  */
 public void initialize(){
    
  //1
  this.first = 1;
  
  this.last = (int)(count / (this.pageSize < 1 ? 20 : this.pageSize) + first - 1);
  
  if (this.count % this.pageSize != 0 || this.last == 0) {
   this.last++;
  }
 
  if (this.last < this.first) {
   this.last = this.first;
  }
  
  if (this.pageNo <= 1) {
   this.pageNo = this.first;
   this.firstPage=true;
  }
 
  if (this.pageNo >= this.last) {
   this.pageNo = this.last;
   this.lastPage=true;
  }
 
  if (this.pageNo < this.last - 1) {
   this.next = this.pageNo + 1;
  } else {
   this.next = this.last;
  }
 
  if (this.pageNo > 1) {
   this.prev = this.pageNo - 1;
  } else {
   this.prev = this.first;
  }
  
  //2
  if (this.pageNo < this.first) {// 如果當前頁小於首頁
   this.pageNo = this.first;
  }
 
  if (this.pageNo > this.last) {// 如果當前頁大於尾頁
   this.pageNo = this.last;
  }
  
 }
 
 /**
  * 預設輸出當前分頁標籤 
  * <div class="page">${page}</div>
  */
 @Override
 public String toString() {
 
  StringBuilder sb = new StringBuilder();
  sb.append("<div class=\"fixed-table-pagination\" style=\"display: block;\">");
//  sb.append("<div class=\"dataTables_info\">");
//  sb.append("<li class=\"disabled controls\"><a href=\"javascript:\">當前 ");
//  sb.append("<input type=\"text\" value=\""+pageNo+"\" onkeypress=\"var e=window.event||this;var c=e.keyCode||e.which;if(c==13)");
//  sb.append(funcName+"(this.value,"+pageSize+",'"+funcParam+"');\" onclick=\"this.select();\"/> / ");
//  sb.append("<input type=\"text\" value=\""+pageSize+"\" onkeypress=\"var e=window.event||this;var c=e.keyCode||e.which;if(c==13)");
//  sb.append(funcName+"("+pageNo+",this.value,'"+funcParam+"');\" onclick=\"this.select();\"/> 條,");
//  sb.append("共 " + count + " 條"+(message!=null?message:"")+"</a></li>\n");
//  sb.append("</div>");
  long startIndex = (pageNo-1)*pageSize + 1;
  long endIndex = pageNo*pageSize <=count? pageNo*pageSize:count;
  
  sb.append("<div class=\"pull-left pagination-detail\">");
  sb.append("<span class=\"pagination-info\">顯示第 "+startIndex+" 到第 "+ endIndex +" 條記錄,總共 "+count+" 條記錄</span>");
  sb.append("<span class=\"page-list\">每頁顯示 <span class=\"btn-group dropup\">");
  sb.append("<button type=\"button\" class=\"btn btn-default  btn-outline dropdown-toggle\" data-toggle=\"dropdown\" aria-expanded=\"false\">");
  sb.append("<span class=\"page-size\">"+pageSize+"</span> <span class=\"caret\"></span>");
  sb.append("</button>");
  sb.append("<ul class=\"dropdown-menu\" role=\"menu\">");
  sb.append("<li class=\""+getSelected(pageSize,10)+ "\"><a href=\"javascript:"+funcName+"("+pageNo+",10,'"+funcParam+"');\">10</a></li>");
  sb.append("<li class=\""+getSelected(pageSize,25)+ "\"><a href=\"javascript:"+funcName+"("+pageNo+",'"+funcParam+"');\">25</a></li>");
  sb.append("<li class=\""+getSelected(pageSize,50)+ "\"><a href=\"javascript:"+funcName+"("+pageNo+",'"+funcParam+"');\">50</a></li>");
  sb.append("<li class=\""+getSelected(pageSize,100)+ "\"><a href=程式設計客棧\"javascript:"+funcName+"("+pageNo+",100,'"+funcParam+"');\">100</a></li>");
  sb.append("</ul>");
  sb.append("</span> 條記錄</span>");
  sb.append("</div>");
//  sb.append("<p>每頁 <select onChange=\""+funcName+"("+pageNo+",'"+funcParam+"');\"" +"style=\"display:display  !important;\" class=\"form-control m-b input-sm\">" +
//          "<option value=\"10\" "+getSelected(pageSize,10)+ ">10</option>" +
//    "<option value=\"25\" "+getSelected(pageSize,25)+ ">25</option>" +
//    "<option value=\"50\" "+getSelected(pageSize,50)+ ">50</option>" +
//    "<option value=\"100\" "+getSelected(pageSize,100)+ ">100</option>" +
//    "</select> 條記錄,顯示 " +startIndex+ " 到 "+ endIndex +" 條,共 "+count+" 條</p>");
//  sb.append("</div>");
//  sb.append("</div>");
  
  
  
  
  sb.append("<div class=\"pull-right pagination-roll\">");
  sb.append("<ul class=\"pagination pagination-outline\">");
  if (pageNo == first) {// 如果是首頁
   sb.append("<li class=\"paginate_button previous disabled\"><a href=\"javascript:\"><i class=\"fa fa-angle-double-left\"></i></a></li>\n");
   sb.append("<li class=\"paginate_button previous disabled\"><a href=\"javascript:\"><i class=\"fa fa-angle-left\"></i></a></li>\n");
  } else {
   sb.append("<li class=\"paginate_button previous\"><a href=\"javascript:\" onclick=\""+funcName+"("+first+",'"+funcParam+"');\"><i class=\"fa fa-angle-double-left\"></i></a></li>\n");
   sb.append("<li class=\"paginate_button previous\"><a href=\"javascript:\" onclick=\""+funcName+"("+prev+",'"+funcParam+"');\"><i class=\"fa fa-angle-left\"></i></a></li>\n");
  }
 
  int begin = pageNo - (length / 2);
 
  if (begin < first) {
   begin = first;
  }
 
  int end = begin + length - 1;
 
  if (end >= last) {
   end = last;
   begin = end - length + 1;
   if (begin < first) {
    begin = first;
   }
  }
 
  if (begin > first) {
   int i = 0;
   for (i = first; i < first + slider && i < begin; i++) {
    sb.append("<li class=\"paginate_button \"><a href=\"javascript:\" onclick=\""+funcName+"("+i+",'"+funcParam+"');\">"
      + (i + 1 - first) + "</a></li>\n");
   }
   if (i < begin) {
    sb.append("<li class=\"paginate_button disabled\"><a href=\"javascript:\">...</a></li>\n");
   }
  }
 
  for (int i = begin; i <= end; i++) {
   if (i == pageNo) {
    sb.append("<li class=\"paginate_button active\"><a href=\"javascript:\">" + (i + 1 - first)
      + "</a></li>\n");
   } else {
    sb.append("<li class=\"paginate_button \"><a href=\"javascript:\" onclick=\""+funcName+"("+i+",'"+funcParam+"');\">"
      + (i + 1 - first) + "</a></li>\n");
   }
  }
 
  if (last - end > slider) {
   sb.append("<li class=\"paginate_button disabled\"><a href=\"javascript:\">...</a></li>\n");
   end = last - slider;
  }
 
  for (int i = end + 1; i <= last; i++) {
   sb.append("<li class=\"paginate_button \"><a href=\"javascript:\" onclick=\""+funcName+"("+i+",'"+funcParam+"');\">"
     + (i + 1 - first) + "</a></li>\n");
  }
 
  if (pageNo == last) {
   sb.append("<li class=\"paginate_button next disabled\"><a href=\"javascript:\"><i class=\"fa fa-angle-right\"></i></a></li>\n");
   sb.append("<li class=\"paginate_button next disabled\"><a href=\"javascript:\"><i class=\"fa fa-angle-double-right\"></i></a></li>\n");
  } else {
   sb.append("<li class=\"paginate_button next\"><a href=\"javascript:\" onclick=\""+funcName+"("+next+",'"+funcParam+"');\">"
     + "<i class=\"fa fa-angle-right\"></i></a></li>\n");
   sb.append("<li class=\"paginate_button next\"><a href=\"javascript:\" onclick=\""+funcName+"("+last+",'"+funcParam+"');\">"
     + "<i class=\"fa fa-angle-double-right\"></i></a></li>\n");
  }
 
  
        sb.append("</ul>");
        sb.append("</div>");
        sb.append("</div>");
//  sb.insert(0,"<ul>\n").append("</ul>\n");
  
//  sb.append("<div style=\"clear:both;\"></div>");
 
//  sb.insert(0,"<div class=\"page\">\n").append("</div>\n");
  
  return sb.toString();
 }
 
 protected String getSelected(int pageNo,int selectedPageNo){
  if(pageNo == selectedPageNo){
   //return "selected";
   return "active";
  }else{
   return "";
  }
  
 }
 /**
  * 獲取分頁HTML程式碼
  * @return
  */
 public String getHtml(){
  return toString();
 }
 
// public static void main(String[] args) {
//  Page<String> p = new Page<String>(3,3);
//  System.out.println(p);
//  System.out.println("首頁:"+p.getFirst());
//  System.out.println("尾頁:"+p.getLast());
//  System.out.println("上頁:"+p.getPrev());
//  System.out.println("下頁:"+p.getNext());
// }
 
 /**
  * 獲取設定總數
  * @return
  */
 public long getCount() {
  return count;
 }
 
 /**
  * 設定資料總數
  * @param count
  */
 public void setCount(long count) {
  this.count = count;
  if (pageSize >= count){
   pageNo = 1;
  }
 }
 
 /**
  * 獲取當前頁碼
  * @return
  */
 public int getPageNo() {
  return pageNo;
 }
 
 /**
  * 設定當前頁碼
  * @param pageNo
  */
 public void setPageNo(int pageNo) {
  this.pageNo = pageNo;
 }
 
 /**
  * 獲取頁面大小
  * @return
  */
 public int getPageSize() {
  return pageSize;
 }
 
 /**
  * 設定頁面大小(最大500)
  * @param pageSize
  */
 public void setPageSiz程式設計客棧e(int pageSize) {
  this.pageSize = pageSize <= 0 ? 10 : pageSize;// > 500 ? 500 : pageSize;
 }
 
 /**
  * 首頁索引
  * @return
  */
 @JsonIgnore
 public int getFirst() {
  return first;
 }
 
 /**
  * 尾頁索引
  * @return
  */
 @JsonIgnore
 public int getLast() {
  return last;
 }
 
 /**
  * 獲取頁面總數
  * @return getLast();
  */
 @JsonIgnore
 public int getTotalPage() {
  return getLast();
 }
 
 /**
  * 是否為第一頁
  * @return
  */
 @JsonIgnore
 public boolean isFirstPage() {
  return firstPage;
 }
 
 /**
  * 是否為最後一頁
  * @return
  */
 @JsonIgnore
 public boolean isLastPage() {
  return lastPage;
 }
 
 /**
  * 上一頁索引值
  * @return
  */
 @JsonIgnore
 public int getPrev() {
  if (isFirstPage()) {
   return pageNo;
  } else {
   return pageNo - 1;
  }
 }
 
 /**
  * 下一頁索引值
  * @return
  */
 @JsonIgnore
 public int getNext() {
  if (isLastPage()) {
   return pageNo;
  } else {
   return pageNo + 1;
  }
 }
 
 /**
  * 獲取本頁資料物件列表
  * @return List<T>
  */
 public List<T> getList() {
  return list;
 }
 
 /**
  * 設定本頁資料物件列表
  * @param list
  */
 public Page<T> setList(List<T> list) {
  this.list = list;
  initialize();
  return this;
 }
 
 /**
  * 獲取查詢排序字串
  * @return
  */
 @JsonIgnore
 public String getOrderBy() {
  // SQL過濾,防止注入 
  String reg = "(?:')|(?:--)|(/\\*(?:.|[\\n\\r])*?\\*/)|"
     + "(\\b(select|update|and|or|delete|insert|trancate|char|into|substr|ascii|declare|exec|count|master|into|drop|execute)\\b)";
  Pattern sqlPattern = Pattern.compile(reg,Pattern.CASE_INSENSITIVE);
  if (sqlPattern.matcher(orderBy).find()) {
   return "";
  }
  return orderBy;
 }
 
 /**
  * 設定查詢排序,標準查詢有效, 例項: updatedate desc,name asc
  */
 public void setOrderBy(String orderBy) {
  this.orderBy = orderBy;
 }
 
 /**
  * 獲取點選頁碼呼叫的js函式名稱
  * function ${page.funcName}(pageNo){location="${ctx}/list-${category.id}${urlSuffix}?pageNo="+i;}
  * @return
  */
 @JsonIgnore
 public String getFuncName() {
  return funcName;
 }
 
 /**
  * 設定點選頁碼呼叫的js函式名稱,預設為page,在一頁有多個分頁物件時使用。
  * @param funcName 預設為page
  */
 public void setFuncName(String funcName) {
  this.funcName = funcName;
 }
 
 /**
  * 獲取分頁函式的附加引數
  * @return
  */
 @JsonIgnore
 public String getFuncParam() {
  return funcParam;
 }
 
 /**
  * 設定分頁函式的附加引數
  * @return
  */
 public void setFuncParam(String funcParam) {
  this.funcParam = funcParam;
 }
 
 /**
  * 設定提示訊息,顯示在“共n條”之後
  * @param message
  */
 public void setMessage(String message) {
  this.message = message;
 }
 
 /**
  * 分頁是否有效
  * @return this.pageSize==-1
  */
 @JsonIgnore
 public boolean isDisabled() {
  return this.pageSize==-1;
 }
 
 /**
  * 是否進行總數統計
  * @return this.count==-1
  */
 @JsonIgnore
 public boolean isNotCount() {
  return this.count==-1;
 }
 
 /**
  * 獲取 Hibernate FirstResult
  */
 public int getFirstResult(){
  int firstResult = (getPageNo() - 1) * getPageSize();
  if (firstResult >= getCount() || firstResult<0) {
   firstResult = 0;
  }
  return firstResult;
 }
 /**
  * 獲取 Hibernate MaxResults
  */
 public int getMaxResults(){
  return getPageSize();
 }
 
// /**
//  * 獲取 Spring data JPA 分頁物件
//  */
// public Pageable getSpringPage(){
//  List<Order> orders = new ArrayList<Order>();
//  if (orderBy!=null){
//   for (String order : StringUtils.split(orderBy,",")){
//    String[] o = StringUtils.split(order," ");
//    if (o.length==1){
//     orders.add(new Order(Direction.ASC,o[0]));
//    }else if (o.length==2){
//     if ("DESC".equals(o[1].toUpperCase())){
//      orders.add(new Order(Direction.DESC,o[0]));
//     }else{
//      orders.add(new Order(Direction.ASC,o[0]));
//     }
//    }
//   }
//  }
//  return new PageRequest(this.pageNo - 1,this.pageSize,new Sort(orders));
// }
// 
// /**
//  * 設定 Spring data JPA 分頁物件,轉換為本系統分頁物件
//  */
// public void setSpringPage(org.springframework.data.domain.Page<T> page){
//  this.pageNo = page.getNumber();
//  this.pageSize = page.getSize();
//  this.count = page.getTotalElements();
//  this.list = page.getContent();
// }
 
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。