bootstraptable 汇总_JS组件系列——表格组件神器:bootstrap table
前言:前面介紹了兩篇關于bootstrap table的基礎用法,這章我們繼續來看看它比較常用的一些功能,來個終結篇吧,毛爺爺告訴我們做事要有始有終~~bootstrap table這東西要想所有功能覆蓋似乎不太現實,博主挑選了一些自認為比較常用的功能在此分享給各位園友。源碼也在這篇統一給出。好了,不多說廢話,開始我們的干貨之旅吧。
bootstrap table系列:
JS組件系列——表格組件神器:bootstrap table
JS組件系列——表格組件神器:bootstrap table(二:父子表和行列調序)
JS組件系列——表格組件神器:bootstrap table(三:終結篇,最后的干貨福利)
一、效果展示
1、表格行樣式
比如我們有一個顯示訂單頁面的需求,不同狀態的訂單顯示不同的顏色,如圖:
2、表格行內編輯
第一篇的時候有園友就問過博主是否可以支持行內編輯的效果,答案是肯定的。我們先來看看效果:
編輯前
點擊某個單元格數據
編輯后完成后
3、表格行列合并
關于行列合并的需求博主覺得是非常常見的,尤其是做頁面報表的時候需要用到。先來看看效果:
當前頁顯示不全,點擊進入看看。怎么樣?效果還不錯吧。
4、表格數據導出
關于表格數據導出,bootstrap table支持三種模式的導出:basic、all、selected。也就是當前頁數據導出、所有數據導出、選中數據導出。并且支持導出多種類型的文件,比如常見的excel、xml、json等格式。
導出當前頁到excel
導出表格所有數據
導出選中行數據
至于其他類型的文件的導出,和excel基本相同,就不做效果展示了。
二、表格行樣式代碼示例
關于表格行的樣式設置,其他是它一個最基礎的功能,為什么要把它放在第三篇?是因為博主覺得這功能可能到處都用得著。當然,效果并不難,自己用jQuery設置tr的背景色也可以實現,但是博主覺得,既然bootstrap table提供了機制設置行的背景色,我們何不用它內置的api呢。我們看看如何實現。
初始化表格的時候
復制代碼
//初始化Table
$('#tb_order').bootstrapTable({
url: '/TableStyle/GetOrder', //請求后臺的URL()
method: 'get', //請求方式()
//toolbar: '#toolbar', //工具按鈕用哪個容器
striped: true, //是否顯示行間隔色
cache: false, //是否使用緩存,默認為true,所以一般情況下需要設置一下這個屬性()
pagination: true, //是否顯示分頁()
sortable: false, //是否啟用排序
sortOrder: "asc", //排序方式
queryParams: oTableInit.queryParams,//傳遞參數()
sidePagination: "server", //分頁方式:client客戶端分頁,server服務端分頁()
pageNumber: 1, //初始化加載第一頁,默認第一頁
pageSize: 10, //每頁的記錄行數()
pageList: [10, 25, 50, 100], //可供選擇的每頁的行數()
search: true, //是否顯示表格搜索,此搜索是客戶端搜索,不會進服務端,所以,個人感覺意義不大
strictSearch: true,
showColumns: true, //是否顯示所有的列
showRefresh: true, //是否顯示刷新按鈕
minimumCountColumns: 2, //最少允許的列數
clickToSelect: true, //是否啟用點擊選中行
height: 500, //行高,如果沒有設置height屬性,表格自動根據記錄條數覺得表格高度
uniqueId: "ID", //每一行的唯一標識,一般為主鍵列
showToggle: true, //是否顯示詳細視圖和列表視圖的切換按鈕
cardView: false, //是否顯示詳細視圖
detailView: false, //是否顯示父子表
rowStyle: function (row, index) {
//這里有5個取值代表5中顏色['active', 'success', 'info', 'warning', 'danger'];
var strclass = "";
if (row.ORDER_STATUS == "待排產") {
strclass = 'success';//還有一個active
}
else if (row.ORDER_STATUS == "已刪除") {
strclass = 'danger';
}
else {
return {};
}
return { classes: strclass }
},
columns: [{
checkbox: true
}, {
field: 'ORDER_NO',
title: '訂單編號'
}, {
field: 'ORDER_TYPE',
title: '訂單類型'
}, {
field: 'ORDER_STATUS',
title: '訂單狀態'
}, {
field: 'REMARK',
title: '備注'
}, ]
});
復制代碼
其實重點就在這個參數里面:
復制代碼
rowStyle: function (row, index) {
//這里有5個取值代表5中顏色['active', 'success', 'info', 'warning', 'danger'];
var strclass = "";
if (row.ORDER_STATUS == "待排產") {
strclass = 'success';//還有一個active
}
else if (row.ORDER_STATUS == "已刪除") {
strclass = 'danger';
}
else {
return {};
}
return { classes: strclass }
},
復制代碼
bootstrap table支持5中表格的行背景色,分別是'active', 'success', 'info', 'warning', 'danger'這五種,至于每種對應的背景顏色,將代碼運行起來就可看到。關于這個方法的返回值,博主第一次用的時候也研究了好久,按照bootstrap table的規則,必須返回一個json格式的對象型如: { classes: strclass } 。
三、表格行內編輯代碼示例
關于表格行內編輯,需要使用bootstrap table擴展的幾個js文件。
1、引入額外的js文件
2、在cshtml頁面定義表格時,添加兩個屬性
復制代碼
部門名稱上級部門部門級別描述
復制代碼
如果是在js里面初始化,寫法如下:
{
field: "name",
title: "名稱",
editable:true
}
3、在js里面初始化表格的時候注冊編輯保存的事件
復制代碼
$('#tb_departments').bootstrapTable({
url: '/Editable/GetDepartment', //請求后臺的URL()
method: 'get', //請求方式()
toolbar: '#toolbar', //工具按鈕用哪個容器
striped: true, //是否顯示行間隔色
cache: false, //是否使用緩存,默認為true,所以一般情況下需要設置一下這個屬性()
pagination: true, //是否顯示分頁()
sortable: false, //是否啟用排序
sortOrder: "asc", //排序方式
queryParams: oTableInit.queryParams,//傳遞參數()
sidePagination: "server", //分頁方式:client客戶端分頁,server服務端分頁()
pageNumber: 1, //初始化加載第一頁,默認第一頁
pageSize: 10, //每頁的記錄行數(*)
onEditableSave: function (field, row, oldValue, $el) {
$.ajax({
type: "post",
url: "/Editable/Edit",
data: { strJson: JSON.stringify(row) },
success: function (data, status) {
if (status == "success") {
alert("編輯成功");
}
},
error: function () {
alert("Error");
},
complete: function () {
}
});
}
});
復制代碼
重點還是看看這個事件的處理方法
復制代碼
onEditableSave: function (field, row, oldValue, $el) {
$.ajax({
type: "post",
url: "/Editable/Edit",
data: { strJson: JSON.stringify(row) },
success: function (data, status) {
if (status == "success") {
alert("編輯成功");
}
},
error: function () {
alert("Error");
},
complete: function () {
}
});
}
復制代碼
對應的方法里面需要自己處理保存的邏輯。四個參數field, row, oldValue, $el分別對應著當前列的名稱、當前行數據對象、更新前的值、編輯的當前單元格的jQuery對象。
四、表格行列合并代碼示例
表格的行列合并功能不用引用其他的js文件,只需要在cshtml頁面使用table的colspan和rowspan即可實現。
1、cshtml頁面
復制代碼
第一季度第二季度第三季度第四季度年度匯總一月二月三月第一季度四月五月六月第二季度七月八月九月第三季度十月十一月十二月第四季度
復制代碼
2、js初始化并無特殊
復制代碼
$('#tb_report').bootstrapTable({
url: '/GroupColumns/GetReport', //請求后臺的URL()
method: 'get', //請求方式()
toolbar: '#toolbar', //工具按鈕用哪個容器
striped: true, //是否顯示行間隔色
cache: false, //是否使用緩存,默認為true,所以一般情況下需要設置一下這個屬性()
pagination: true, //是否顯示分頁()
sortOrder: "asc", //排序方式
queryParams: oTableInit.queryParams,//傳遞參數()
sidePagination: "server", //分頁方式:client客戶端分頁,server服務端分頁()
pageNumber: 1, //初始化加載第一頁,默認第一頁
pageSize: 10, //每頁的記錄行數()
pageList: [10, 25, 50, 100], //可供選擇的每頁的行數()
});
復制代碼
怎么樣,有沒有很簡單。當然,有人說了,你都可以不用js初始化,直接在cshtml里面用table的屬性去設置url、分頁等信息。確實,如果我們看過它的api,會發現它初始化的每一個屬性都對應一個table的屬性。型如
如果你的表格沒有一些特殊的事件需要處理,這樣是完全沒有問題的。
五、表格數據導出代碼示例
表格數據的導出功能也需要一些擴展的js支持。
1、引入額外的js文件
2、js初始化的時候
復制代碼
$('#tb_departments').bootstrapTable({
url: '/Export/GetDepartment', //請求后臺的URL()
method: 'get', //請求方式()
toolbar: '#toolbar', //工具按鈕用哪個容器
striped: true, //是否顯示行間隔色
cache: false, //是否使用緩存,默認為true,所以一般情況下需要設置一下這個屬性()
pagination: true, //是否顯示分頁()
sortable: false, //是否啟用排序
sortOrder: "asc", //排序方式
queryParams: oTableInit.queryParams,//傳遞參數()
sidePagination: "client", //分頁方式:client客戶端分頁,server服務端分頁()
pageNumber: 1, //初始化加載第一頁,默認第一頁
pageSize: 10, //每頁的記錄行數()
pageList: [10, 25, 50, 100], //可供選擇的每頁的行數()
clickToSelect:true,
showExport: true, //是否顯示導出
exportDataType: "basic", //basic', 'all', 'selected'.
columns: [{
checkbox: true
}, {
field: 'Name',
title: '部門名稱'
}, {
field: 'ParentName',
title: '上級部門'
}, {
field: 'Level',
title: '部門級別'
}, {
field: 'Desc',
title: '描述'
}, ]
});
復制代碼
還是來看重點:這兩個屬性
showExport: true, //是否顯示導出
exportDataType: "basic", //basic', 'all', 'selected'.
showExport表示是否顯示導出的按鈕,exportDataType表示導出的模式是當前頁、所有數據還是選中數據。
六、總結
以上就是功能的效果以及實現的簡單代碼。博主發現有幾個問題有待解決。
1、行內編輯的功能是每一個單元格提交到后臺,這樣會造成數據庫的頻繁操作,感覺不太合適。不知道有沒有更好的方式,每行提交到后臺。
2、導出的功能雖然很好用,但是遺憾的是不支持IE瀏覽器,博主試過官網上面的example,好像IE也導出不了。待驗證。
總結
以上是生活随笔為你收集整理的bootstraptable 汇总_JS组件系列——表格组件神器:bootstrap table的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 男性精子检查要多久
- 下一篇: 求队开头的成语接龙!