溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

bootstrap如何實(shí)現(xiàn)table分頁

發(fā)布時(shí)間:2021-02-03 10:30:24 來源:億速云 閱讀:753 作者:小新 欄目:web開發(fā)

這篇文章主要介紹了bootstrap如何實(shí)現(xiàn)table分頁,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

bootstrap table分頁的兩種方式:

前端分頁:一次性從數(shù)據(jù)庫查詢所有的數(shù)據(jù),在前端進(jìn)行分頁(數(shù)據(jù)量小的時(shí)候或者邏輯處理不復(fù)雜的話可以使用前端分頁)

服務(wù)器分頁:每次只查詢當(dāng)前頁面加載所需要的那幾條數(shù)據(jù)

bootstrap 下載地址:http://www.bootcss.com/

bootstrap-table 下載地址:http://bootstrap-table.wenzhixin.net.cn/

jquery下載地址:http://www.jq22.com/jquery-info122

分頁效果(請(qǐng)忽略樣式)

bootstrap如何實(shí)現(xiàn)table分頁

一:準(zhǔn)備js、css等文件

? 將下載的文檔直接放入webapp目錄下

bootstrap如何實(shí)現(xiàn)table分頁

?頁面引入需要的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頁面標(biāo)簽內(nèi)容

<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">手機(jī)號(hào):</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",//請(qǐng)求路徑
	striped : true, //是否顯示行間隔色
	pageNumber : 1, //初始化加載第一頁
	pagination : true,//是否分頁
	sidePagination : 'client',//server:服務(wù)器端分頁|client:前端分頁
	pageSize : 4,//單頁記錄數(shù)
	pageList : [ 5, 10, 20, 30 ],//可選擇單頁記錄數(shù)
	showRefresh : true,//刷新按鈕
	queryParams : function(params) {//上傳服務(wù)器的參數(shù)
		var temp = {//如果是在服務(wù)器端實(shí)現(xiàn)分頁,limit、offset這兩個(gè)參數(shù)是必須的
			limit : params.limit, // 每頁顯示數(shù)量
			offset : params.offset, // SQL語句起始索引
			//page : (params.offset / params.limit) + 1, //當(dāng)前頁碼 
 
			Name : $('#search_name').val(),
			Tel : $('#search_tel').val()
		};
		return temp;
	},
	columns : [ {
		title : '登錄名',
		field : 'loginName',
		sortable : true
	}, {
		title : '姓名',
		field : 'name',
		sortable : true
	}, {
		title : '手機(jī)號(hào)',
		field : 'tel',
	}, {
		title : '性別',
		field : 'sex',
		formatter : formatSex,//對(duì)返回的數(shù)據(jù)進(jìn)行處理再顯示
	}, {
		title : '操作',
		field : 'id',
		formatter : operation,//對(duì)資源進(jìn)行操作
	} ]
})
 
//value代表該列的值,row代表當(dāng)前對(duì)象
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 實(shí)現(xiàn)前端分頁

? 修改JS分頁代碼中某些屬性

sidePagination:'client',
queryParams : function (params) {
        var temp = {
            name:$('#search_name').val(),
            tel:$('#search_tel').val()
        };
        return temp;
    },

? 定義user對(duì)象

package com.debo.common;

public class User {
	
	private Integer id;
	private String loginName;
	private String name;
	private String tel;
	private Integer sex;
	
        //省略Get/Set函數(shù)
}

? 服務(wù)器Controller層代碼

/**
*直接一次性查出所有的數(shù)據(jù),返回給前端,bootstrap-table自行分頁
*/
@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>

五:bootstrap-table 實(shí)現(xiàn)服務(wù)器端分頁

? 設(shè)置JS分頁代碼中的某些屬性

sidePagination:'server',
queryParams : function (params) {
    var temp = {
        limit : params.limit, // 每頁顯示數(shù)量
        offset : params.offset, // SQL語句起始索引
        page: (params.offset / params.limit) + 1,   //當(dāng)前頁碼
            
        Name:$('#search_name').val(),
        Tel:$('#search_tel').val()
    };
    return temp;
},

? 封裝公共的page對(duì)象,并讓user對(duì)象繼承page對(duì)象

package com.debo.common;

public class Page {
	//每頁顯示數(shù)量
	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;
	}
}

? 封裝返回?cái)?shù)據(jù)實(shí)體類

package com.debo.common;

import java.util.ArrayList;
import java.util.List;

public class PageHelper<T> {
    //實(shí)體類集合
    private List<T> rows = new ArrayList<T>();
    //數(shù)據(jù)總條數(shù)
    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;
    }

}

? 服務(wù)器Controller層代碼

@RequestMapping("/getUserListPage")
@ResponseBody
public PageHelper<User> getUserListPage(User user,HttpServletRequest request) {
		
        PageHelper<User> pageHelper = new PageHelper<User>();
	// 統(tǒng)計(jì)總記錄數(shù)
	Integer total = userService.getTotal(user);
	pageHelper.setTotal(total);

	// 查詢當(dāng)前頁實(shí)體對(duì)象
	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 #{offset},#{limit}
</select>

tip:增、刪、改操作后重新加載表格

$("#mytab").bootstrapTable('refresh', {url : url});

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“bootstrap如何實(shí)現(xiàn)table分頁”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI