亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JS組件系列之Bootstrap table表格組件神器【終結篇】

2019-11-20 10:06:59
字體:
來源:轉載
供稿:網友

bootstrap table系列:

JS表格組件神器bootstrap table詳解(基礎版)

JS組件系列之Bootstrap table表格組件神器【終結篇】

JS組件系列之Bootstrap table表格組件神器【二、父子表和行列調序】

Bootstrap Table是輕量級的和功能豐富的以表格的形式顯示的數據,支持單選,復選框,排序,分頁,顯示/隱藏列,固定標題滾動表,響應式設計,Ajax加載JSON數據,點擊排序的列,卡片視圖等。那么本文給大家介紹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文件

<link rel="stylesheet" ><script src="http://rawgit.com/vitalets/x-editable/master/dist/bootstrap3-editable/js/bootstrap-editable.js"></script><script src="~/Content/bootstrap-table/extensions/editable/bootstrap-table-editable.js"></script> 

2、在cshtml頁面定義表格時,添加兩個屬性

<table id="tb_departments"><thead><tr><th data-field="Name" data-editable="true">部門名稱</th><th data-field="ParentName">上級部門</th><th data-field="Level" data-editable="true">部門級別</th><th data-field="Desc" data-editable="true">描述</th></tr></thead></table> 

如果是在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頁面

<table id="tb_report"><thead><tr><th colspan="4" data-valign="middle" data-align="center">第一季度</th><th colspan="4" data-valign="middle" data-align="center">第二季度</th><th colspan="4" data-valign="middle" data-align="center">第三季度</th><th colspan="4" data-valign="middle" data-align="center">第四季度</th><th data-field="TotalCount" rowspan="2" data-valign="middle" data-align="center">年度匯總</th></tr><tr><th data-field="JanCount" data-align="center">一月</th><th data-field="FebCount" data-align="center">二月</th><th data-field="MarCount" data-align="center">三月</th><th data-field="FirstQuarter" data-align="center">第一季度</th><th data-field="AprCount" data-align="center">四月</th><th data-field="MayCount" data-align="center">五月</th><th data-field="JunCount" data-align="center">六月</th><th data-field="SecondQuarter" data-align="center">第二季度</th><th data-field="JulCount" data-align="center">七月</th><th data-field="AguCount" data-align="center">八月</th><th data-field="SepCount" data-align="center">九月</th><th data-field="ThirdQuarter" data-align="center">第三季度</th><th data-field="OctCount" data-align="center">十月</th><th data-field="NovCount" data-align="center">十一月</th><th data-field="DecCount" data-align="center">十二月</th><th data-field="ForthQuarter" data-align="center">第四季度</th></tr></thead></table> 

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文件

<script src="~/Content/bootstrap-table/extensions/export/bootstrap-table-export.js"></script><script src="http://rawgit.com/hhurz/tableExport.jquery.plugin/master/tableExport.js"></script>

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也導出不了。待驗證。

以上所述是小編給大家介紹的JS組件系列之Bootstrap table表格組件神器【終結篇】的相關內容,希望對大家有所幫助!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲va久久久噜噜噜| 日韩欧美亚洲综合| 狠狠色香婷婷久久亚洲精品| 国产成人精品视频| 久久精品久久久久久国产 免费| 久久免费视频网| 欧美日韩亚洲视频一区| 狠狠躁18三区二区一区| 国内自拍欧美激情| 一区二区三区四区在线观看视频| 久久亚洲春色中文字幕| 久久精品国产综合| 久久国产精品久久精品| 日本欧美黄网站| 久久免费国产视频| 综合激情国产一区| 久久精品国产久精国产一老狼| 日韩高清有码在线| 亚洲a区在线视频| 亚洲а∨天堂久久精品喷水| 欧美国产视频一区二区| 久热精品视频在线免费观看| 国产一区二区三区直播精品电影| 91av在线看| 美女精品视频一区| 亚洲国产精品嫩草影院久久| 97香蕉久久超级碰碰高清版| 亚洲黄色有码视频| 国产精品国语对白| 国产日韩欧美91| 91亚洲va在线va天堂va国| 欧美日韩国产综合视频在线观看中文| 日韩国产激情在线| 久久久久九九九九| 欧美激情综合亚洲一二区| 国产精品ⅴa在线观看h| 久久人人爽人人爽人人片亚洲| 亚洲精品久久7777777| 亚洲综合色激情五月| 精品福利樱桃av导航| 最近免费中文字幕视频2019| 91精品在线国产| 久久精品成人欧美大片古装| 一个人www欧美| 日韩三级成人av网| wwwwwwww亚洲| 国内精品久久久久久久| 人妖精品videosex性欧美| 免费91麻豆精品国产自产在线观看| 成人免费自拍视频| 久久久伊人欧美| 国产精品福利在线观看网址| 欧美性xxxxx| 国产精品嫩草影院一区二区| 在线观看日韩视频| 国产精品高潮呻吟久久av黑人| 国自在线精品视频| 日韩在线激情视频| 亚洲一级黄色片| 午夜免费在线观看精品视频| 国产一区二区三区欧美| 精品日本高清在线播放| 欧美日韩在线第一页| 日韩美女视频免费在线观看| 日韩精品欧美国产精品忘忧草| 91精品在线看| 亚洲精品www久久久| 秋霞成人午夜鲁丝一区二区三区| 亚洲成人黄色在线观看| 欧美性资源免费| 日韩欧美亚洲范冰冰与中字| 亚洲天堂免费视频| 成人写真福利网| 69av在线视频| 日本一区二区在线播放| 国产日韩欧美电影在线观看| 亚洲国产日韩欧美在线图片| 精品久久久久久久久久| 日韩中文字幕在线精品| 亚洲欧美福利视频| 黑人巨大精品欧美一区二区免费| 精品久久久香蕉免费精品视频| 亚洲最大激情中文字幕| 日韩成人小视频| 日韩av电影国产| 91最新在线免费观看| 国产美女被下药99| 中文字幕亚洲情99在线| 亚洲天堂av高清| 久久国产精品久久久| 国产欧美一区二区三区在线看| 欧美日韩中国免费专区在线看| 欧美理论电影在线播放| 欧美高跟鞋交xxxxxhd| 姬川优奈aav一区二区| 国产精品日韩欧美大师| 一区二区欧美亚洲| 国产精品jvid在线观看蜜臀| 97av在线影院| 日韩h在线观看| 国产91精品久久久| 欧美成人精品激情在线观看| 国产亚洲在线播放| 国产亚洲激情视频在线| 26uuu另类亚洲欧美日本老年| 亚洲男人天堂手机在线| 日韩中文视频免费在线观看| 日韩电影中文字幕| 97在线观看视频| 欧美性极品xxxx娇小| 日韩视频免费在线| 亚洲国产成人精品久久久国产成人一区| 福利一区视频在线观看| 色婷婷**av毛片一区| 国产精品老女人精品视频| 亚洲精品免费一区二区三区| 欧美成人黑人xx视频免费观看| 国产a∨精品一区二区三区不卡| 国产亚洲一区二区在线| 国产精品91免费在线| 亚洲国产精品中文| 欧美色播在线播放| 午夜精品在线观看| 色综合久久久888| 欧美高清自拍一区| 免费不卡在线观看av| 久久久999国产精品| 欧美专区日韩视频| 91高清免费视频| 日韩欧美高清在线视频| 亚洲欧美色婷婷| 在线观看日韩av| 欧美性受xxxx白人性爽| 欧美日韩一区免费| 欧美亚洲免费电影| 97热精品视频官网| 精品精品国产国产自在线| 色噜噜国产精品视频一区二区| 国产精品成人观看视频国产奇米| 亚洲综合日韩在线| 欧美性猛交xxxx乱大交蜜桃| 国产精品久久久久久久久久久久久久| 亚洲成人网av| 欧美色视频日本高清在线观看| 欧美裸体xxxx| 久久久久久亚洲精品不卡| 91精品国产亚洲| 啪一啪鲁一鲁2019在线视频| 国产精品九九久久久久久久| 亚洲国产精品热久久| 久久久噜噜噜久久中文字免| 好吊成人免视频| 日韩av成人在线| 国产精品看片资源| 亚洲欧美成人精品| 午夜美女久久久久爽久久| 亚洲另类欧美自拍| 国产精品91一区| 久久福利视频导航| 午夜精品一区二区三区在线视| 日韩美女视频免费看| 北条麻妃一区二区在线观看| 中文字幕视频一区二区在线有码| 国产精品视频网址|