bootstrapTable的使用总结

Posted 晨港飞燕

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了bootstrapTable的使用总结相关的知识,希望对你有一定的参考价值。

官网资料:https://examples.bootstrap-table.com/#

动态表头

(function(document, window, $) 

// Example Bootstrap Table Large Columns
  // -------------------------------------
  buildTable($('#exampleTableLargeColumns'), 50, 50);





function buildTable($el, cells, rows) 
  var i, j, row,
    columns = [],
    data = [];

  for (i = 0; i < cells; i++) 
    columns.push(
      field: '字段' + i,
      title: '单元' + i
    );
  
  for (i = 0; i < rows; i++) 
    row = ;
    for (j = 0; j < cells; j++) 
      row['字段' + j] = 'Row-' + i + '-' + j;
    
    data.push(row);
  
  $el.bootstrapTable('destroy').bootstrapTable(
    columns: columns,
    data: data,
    iconSize: 'outline',
    icons: 
      columns: 'glyphicon-list'
    
  );

JSON形式

 

var columns = [],data = [];
			//表头
			//三个json,三列
			columns.push(
				field: '2021-5',
				title: '2021-5'
			,
				field: '2021-6',
				title: '2021-6'
			,
				field: '2021-7',
				title: '2021-7'
			,
				field: '2021-8',
				title: '2021-8'
			);
			//表格数据
			//三行三json,列数随属性个数变化
			data.push(
			
				'2021-5': '门店1',
				'2021-6': '门店1',
				'2021-7': '门店1'
			,
			
				'2021-5': '走访2',
				'2021-6': '走访2',
				'2021-7': '走访2'
			,	
				'2021-5': '经纪3',
				'2021-6': '经纪3',
				'2021-7': '经纪3'
			,
			);

 效果图


复杂表头:

 效果图

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: '消息',
                colspan: 2,
                align: 'center'
            , 
                title: '海报模板',
                colspan: 2,
                align: 'center'
            , 
                title: '楼盘动态',
                colspan: 2,
                align: 'center'
            , 
                title: '项目卖点',
                colspan: 2,
                align: 'center'
            , 
                title: '项目海报',
                colspan: 2,
                align: 'center'
            , 
                title: '项目视频',
                colspan: 2,
                align: 'center'
            ],
            [
                field: 'newsCount',
                title: '更新次数',
            
                , 
                field: 'newsState',
                title:"-",
                class:'newsTitle',
                formatter: function (value, row, 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',
                formatter: function (value, row, index) 
                    if (value=='不合格') 
                        return "<span style=\\"color: red;\\">不合格<span>";
                    
                    return value;
                

            
                , 
                field: 'tempCount',
                title: '更新次数'
            , 
                field: 'tempState',
                title: '-',
                class:'tempTitle',
                formatter: function (value, row, index) 
                    if (value=='不合格') 
                        return "<span style=\\"color: red;\\">不合格<span>";
                    
                    return value;
                

            ,
                
                    field: 'houseCount',
                    title: '更新次数'
                , 
                field: 'houseState',
                title: '-',
                class:'houseTitle',
                formatter: function (value, row, index) 
                    if (value=='不合格') 
                        return "<span style=\\"color: red;\\">不合格<span>";
                    
                    return value;
                

            ,
                
                    field: 'sellCount',
                    title: '更新次数'

                , 
                field: 'sellState',
                title: '-',
                class:'sellTitle',
                formatter: function (value, row, index) 
                    if (value=='不合格') 
                        return "<span style=\\"color: red;\\">不合格<span>";
                    
                    return value;
                

            ,
                
                    field: 'postCount',
                    title: '更新次数'

                , 
                field: 'postState',
                title: '-',
                class:'postTitle',
                formatter: function (value, row, index) 
                    if (value=='不合格') 
                        return "<span style=\\"color: red;\\">不合格<span>";
                    
                    return value;
                

            , 
                field: 'videoCount',
                title: '更新次数'

            
                , 
                field: 'videoState',
                title: '-',
                class:'videoTitle',
                formatter: function (value, row, 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 dateTypeAll=='today'">
            select
            cityName,
            projectName,
            newsCount,
            '-' newsState,
            msgCount,
            '-' msgState,
            tempCount,
            '-' tempState,
            houseCount,
            '-' houseState,
            sellCount,
            '-' sellState,
            postCount,
            '-' postState,
            videoCount,
            '-' videoState
        </if>

        <if test="dateTypeAll == 'weeks' or dateTypeAll == 'month' or dateTypeAll=='halfYear' or dateTypeAll=='years'">
            select
            cityName,
            projectName,
            newsCount,
            CASE  WHEN newsCount > #newsNum THEN '合格'  ELSE '不合格' END newsState,
            msgCount,
            CASE  WHEN msgCount >  #msgNum THEN '合格' ELSE '不合格' END msgState,
            tempCount,
            CASE  WHEN tempCount >  #tempNum THEN '合格' ELSE '不合格' END tempState,
            houseCount,
            CASE  WHEN houseCount > #houseNum THEN '合格' ELSE '不合格' END houseState,
            sellCount,
            CASE  WHEN sellCount > #sellNum THEN '合格' ELSE '不合格' END sellState,
            postCount,
            CASE  WHEN postCount > #postNum THEN '合格' ELSE '不合格' END postState,
            videoCount,
            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[>=]]>  #startDate
			</if>
        <if test="endDate != null and endDate != ''">
				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[>=]]>  #startDate
			</if>
        <if test="endDate != null and endDate != ''">
				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[>=]]>  #startDate
			</if>
        <if test="endDate != null and endDate != ''">
				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[>=]]>  #startDate
			</if>
        <if test="endDate != null and endDate != ''">
				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[>=]]>  #startDate
			</if>
        <if test="endDate != null and endDate != ''">
				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[>=]]>  #startDate
			</if>
        <if test="endDate != null and endDate != ''">
				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/">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, pageSize, count, new ArrayList<T>());
	
	
	/**
	 * 构造方法
	 * @param pageNo 当前页码
	 * @param pageSize 分页大小
	 * @param count 数据条数
	 * @param list 本页数据对象列表
	 */
	public Page(int pageNo, int pageSize, 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+",25,'"+funcParam+"');\\">25</a></li>");
		sb.append("<li class=\\""+getSelected(pageSize,50)+ "\\"><a href=\\"javascript:"+funcName+"("+pageNo+",50,'"+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+",this.value,'"+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+","+pageSize+",'"+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+","+pageSize+",'"+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+","+pageSize+",'"+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+","+pageSize+",'"+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+","+pageSize+",'"+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+","+pageSize+",'"+funcParam+"');\\">"
					+ "<i class=\\"fa fa-angle-right\\"></i></a></li>\\n");
			sb.append("<li class=\\"paginate_button next\\"><a href=\\"javascript:\\" onclick=\\""+funcName+"("+last+","+pageSize+",'"+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 setPageSize(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();
//	
	

以上是关于bootstrapTable的使用总结的主要内容,如果未能解决你的问题,请参考以下文章

bootstraptable使用总结之前端样式设计

如何来使用bootstrap table

JS组件系列——BootstrapTable 行内编辑解决方案:x-editable

ApiCloud开发经验总结

使用JQuery实现对BootstrapTable复选框checkbox的动态选中

bootstrap的table怎么绑定后台返回的json数据