1. 程式人生 > >JS元件系列——表格元件神器:bootstrap table(三:終結篇,最後的乾貨福利)

JS元件系列——表格元件神器:bootstrap table(三:終結篇,最後的乾貨福利)

前言:前面介紹了兩篇關於bootstrap table的基礎用法,這章我們繼續來看看它比較常用的一些功能,來個終結篇吧,毛爺爺告訴我們做事要有始有終~~bootstrap table這東西要想所有功能覆蓋似乎不太現實,博主挑選了一些自認為比較常用的功能在此分享給各位園友。原始碼也在這篇統一給出。好了,不多說廢話,開始我們的乾貨之旅吧。

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" href="//rawgit.com/vitalets/x-editable/master/dist/bootstrap3-editable/css/bootstrap-editable.css">
<script src="//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="//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也匯出不了。待驗證。

原始碼提供出來,園友們有興趣可以看看。原始碼下載

最近打算做點自己的東西出來,將部落格裡面的一些好的技術融合進去。有專案合作的小夥伴趕快聯絡博主吧!