bootstrap Table從零開始

 

 

本文博主將從零開始,一步一步的告訴你們如何在前端用bootstrap Table插件展現一個表格css

首先,要下載bootstrap Table插件所必須的js,地址:https://github.com/wenzhixin/bootstrap-tablehtml

官方文檔地址:http://bootstrap-table.wenzhixin.net.cn/zh-cn/documentation/前端

 本文項目地址:https://pan.baidu.com/s/1sk9w6D3jquery


 本文須要注意點地方博主已用紅筆圈起來git

先展現效果圖github

 

 


 

接下來就開始使用bootstrap Table插件製做表格數據庫

將上述地址下載的插件js放到項目中,分別爲js,css,fontsjson

此處有一個細節:locale文件夾的名字不能修改,並且裏邊的全部語言js,必須所有粘過來bootstrap

本文以MVC爲例,固然WebForm也是能夠的瀏覽器

使用步驟:

一、新建一個控制器和視圖,該視圖引用了_Layout母頁版

二、在視圖裏引用相應的js

在頁面上寫一個table表格容器,這一句必需要有

<table id="ArbetTable"></table>

三、初始化bootstrap Table

1 $(function () {
     //1.初始化Table
     var oTable = new TableInit();
    oTable.Init();
});

四、使用bootstrap Table

var TableInit = function () {
    var oTableInit = new Object();
    //初始化Table
    oTableInit.Init = function () {
        $('#ArbetTable').bootstrapTable({
            url: '/Interface/GetData',         //請求後臺的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,                       //是否顯示錶格搜索,此搜索是客戶端搜索,不會進服務端,因此,我的感受意義不大
            contentType: "application/x-www-form-urlencoded",
            strictSearch: true,
            showColumns: true,                  //是否顯示全部的列
            showRefresh: true,                  //是否顯示刷新按鈕
            minimumCountColumns: 2,             //最少容許的列數
            clickToSelect: true,                //是否啓用點擊選中行
            height: 700,                        //行高,若是沒有設置height屬性,表格自動根據記錄條數以爲表格高度
            uniqueId: "no",                     //每一行的惟一標識,通常爲主鍵列
            showToggle: true,                    //是否顯示詳細視圖和列表視圖的切換按鈕
            cardView: false,                    //是否顯示詳細視圖
            detailView: false,                   //是否顯示父子表
            columns: [
            {
                field: 'ID',
                title: 'ID'
            }, {
                field: 'Name',
                title: '名字'
            }, {
                field: 'Sex',
                title: '性別'
            },
            {
                field: 'operate',
                title: '操做',
                formatter: operateFormatter //自定義方法,添加操做按鈕
            },
            ],
            rowStyle: function (row, index) {
                var classesArr = ['success', 'info'];
                var strclass = "";
                if (index % 2 === 0) {//偶數行
                    strclass = classesArr[0];
                } else {//奇數行
                    strclass = classesArr[1];
                }
                return { classes: strclass };
            },//隔行變色
        });

    };


    //獲得查詢的參數
    oTableInit.queryParams = function (params) {
        var temp = {   //這裏的鍵的名字和控制器的變量名必須一直,這邊改動,控制器也須要改爲同樣的
            limit: params.limit,   //頁面大小
            offset:params.offset
        };
        return temp;
    };
    return oTableInit;
};


function operateFormatter(value, row, index) {//賦予的參數
    return [
        '<a class="btn active disabled" href="#">編輯</a>',
        '<a class="btn active" href="#">檔案</a>',
        '<a class="btn btn-default" href="#">記錄</a>',
        '<a class="btn active" href="#">准入</a>'
    ].join('');
}

  

後臺url返回數據

複製代碼
public ActionResult GetData(int limit, int offset)
        {
            var data = new List<object>(){new { ID=1, Name="Arbet", Sex="男"},
                new { ID= 2, Name="Arbet1", Sex="女" },
                new {ID=3, Name="Arbet2",Sex="男" },
                new {ID=4, Name="Arbet3",Sex="女" },
                new {ID=5, Name="Arbet4",Sex="男" },
                new {ID=6, Name="Arbet5",Sex="男" },
                new {ID=7, Name="Arbet6",Sex="女" },
                new {ID=8, Name="Arbet7",Sex="男" },
                new { ID=9, Name="Arbet1", Sex="女" },
                new {ID=10, Name="Arbet2",Sex="男" },
                new {ID=11, Name="Arbet3",Sex="女" },
                new {ID=12, Name="Arbet4",Sex="男" },
                new {ID=13, Name="Arbet5",Sex="男" },
                new {ID=14, Name="Arbet6",Sex="女" },
                new {ID=15, Name="Arbet7",Sex="男" }
            };
            var total = data.Count;
            var rows = data.Skip(offset).Take(limit).ToList();
            return Json(new { total = total, rows = rows }, JsonRequestBehavior.AllowGet);
        }
複製代碼

在本文中,博主以匿名集合來設置數據,你們能夠經過查詢數據庫獲取數據

在此須要注意:返回的參數必須是total和rows,total返回數據集總個數,rows返回table的json格式

 

五、展現效果

發現出現了這個bug,這是怎麼回事

在瀏覽器上打開源代碼

發現多了一些其餘js文件,這是layout母頁版裏引入的js文件

複製代碼
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width" />
    <title>@ViewBag.Title</title>
    @Styles.Render("~/Content/css")
    @Scripts.Render("~/bundles/modernizr")
</head>
<body>
    @RenderBody()

    @*@Scripts.Render("~/bundles/jquery")*@
    @RenderSection("scripts", required: false)
</body>
</html>
複製代碼

把上圖中的紅框裏的js文件註釋掉再運行

發現成功了!這是由於JS庫文件的引用是有順序的,必須先引用JQuery庫文件,再引用插件js

相關文章
相關標籤/搜索