這篇文章主要介紹了web開發(fā)中bootstrap-table如何分頁(yè),具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
在欽北等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站制作、網(wǎng)站設(shè)計(jì) 網(wǎng)站設(shè)計(jì)制作按需求定制網(wǎng)站,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),成都品牌網(wǎng)站建設(shè),營(yíng)銷型網(wǎng)站建設(shè),成都外貿(mào)網(wǎng)站制作,欽北網(wǎng)站建設(shè)費(fèi)用合理。
bootstrap table分頁(yè)的兩種方式:
前端分頁(yè):一次性從數(shù)據(jù)庫(kù)查詢所有的數(shù)據(jù),在前端進(jìn)行分頁(yè)(數(shù)據(jù)量小的時(shí)候或者邏輯處理不復(fù)雜的話可以使用前端分頁(yè))
服務(wù)器分頁(yè):每次只查詢當(dāng)前頁(yè)面加載所需要的那幾條數(shù)據(jù)
bootstrap 下載地址:http://www.bootcss.com/
bootstrap-table 下載地址:http://bootstrap-table.wenzhixin.net.cn/
jquery下載地址:http://www.jq22.com/jquery-info122
分頁(yè)效果(請(qǐng)忽略樣式)
一:準(zhǔn)備js、css等文件
? 將下載的文檔直接放入webapp目錄下
?頁(yè)面引入需要的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頁(yè)面標(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分頁(yè)代碼
$('#mytab').bootstrapTable({ method : 'get', url : "user/getUserListPage",//請(qǐng)求路徑 striped : true, //是否顯示行間隔色 pageNumber : 1, //初始化加載第一頁(yè) pagination : true,//是否分頁(yè) sidePagination : 'client',//server:服務(wù)器端分頁(yè)|client:前端分頁(yè) pageSize : 4,//單頁(yè)記錄數(shù) pageList : [ 5, 10, 20, 30 ],//可選擇單頁(yè)記錄數(shù) showRefresh : true,//刷新按鈕 queryParams : function(params) {//上傳服務(wù)器的參數(shù) var temp = {//如果是在服務(wù)器端實(shí)現(xiàn)分頁(yè),limit、offset這兩個(gè)參數(shù)是必須的 limit : params.limit, // 每頁(yè)顯示數(shù)量 offset : params.offset, // SQL語(yǔ)句起始索引 //page : (params.offset / params.limit) + 1, //當(dāng)前頁(yè)碼 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)前端分頁(yè)
? 修改JS分頁(yè)代碼中某些屬性
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自行分頁(yè) */ @RequestMapping("/getUserListPage") @ResponseBody public List<User> getUserListPage(User user,HttpServletRequest request){ List<User> list = userService.getUserListPage(user); return list; }
? mabatis語(yǔ)句
<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ù)器端分頁(yè)
? 設(shè)置JS分頁(yè)代碼中的某些屬性
sidePagination:'server', queryParams : function (params) { var temp = { limit : params.limit, // 每頁(yè)顯示數(shù)量 offset : params.offset, // SQL語(yǔ)句起始索引 page: (params.offset / params.limit) + 1, //當(dāng)前頁(yè)碼 Name:$('#search_name').val(), Tel:$('#search_tel').val() }; return temp; },
? 封裝公共的page對(duì)象,并讓user對(duì)象繼承page對(duì)象
package com.debo.common; public class Page { //每頁(yè)顯示數(shù)量 private int limit; //頁(yè)碼 private int page; //sql語(yǔ)句起始索引 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)前頁(yè)實(shí)體對(duì)象 List<User> list = userService.getUserListPage(user); pageHelper.setRows(list); return pageHelper; }
? mybatis語(yǔ)句
<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)真閱讀完這篇文章,希望小編分享的“web開發(fā)中bootstrap-table如何分頁(yè)”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!
本文標(biāo)題:web開發(fā)中bootstrap-table如何分頁(yè)
路徑分享:http://www.rwnh.cn/article40/phocho.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機(jī)、網(wǎng)站內(nèi)鏈、小程序開發(fā)、靜態(tài)網(wǎng)站、商城網(wǎng)站、外貿(mào)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)