Bootstrap Table從零開始
本文博主將從零開始,一步一步的告訴大家如何在前端用bootstrap Table插件展示一個表格
首先,要下載bootstrap Table插件所必須的js,地址:https://github.com/wenzhixin/bootstrap-table
官方文檔地址:http://bootstrap-table.wenzhixin.net.cn/zh-cn/documentation/
本文項目地址:bootstraptable
本文需要注意點地方博主已用紅筆圈起來
先展示效果圖

接下來就開始使用bootstrap Table插件制作表格
將上述地址下載的插件js放到項目中,分別為js,css,fonts

此處有一個細節(jié):locale文件夾的名字不能修改,而且里邊的所有語言js,必須全部粘過來
本文以MVC為例,當然WebForm也是可以的
使用步驟:
1、新建一個控制器和視圖,該視圖引用了_Layout母頁版
2、在視圖里引用相應的js

在頁面上寫一個table表格容器,這一句必須要有
<table id="ArbetTable"></table>
3、初始化bootstrap Table
$(function () {
//1.初始化Table
var oTable = new TableInit();
oTable.Init();
});
4、使用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,//傳遞參數(shù)(*)
sidePagination: "server", //分頁方式:client客戶端分頁,server服務端分頁(*)
pageNumber: 1, //初始化加載第一頁,默認第一頁
pageSize: 10, //每頁的記錄行數(shù)(*)
pageList: [10, 25, 50, 100], //可供選擇的每頁的行數(shù)(*)
search: true, //是否顯示表格搜索,此搜索是客戶端搜索,不會進服務端,所以,個人感覺意義不大
contentType: "application/x-www-form-urlencoded",
strictSearch: true,
showColumns: true, //是否顯示所有的列
showRefresh: true, //是否顯示刷新按鈕
minimumCountColumns: 2, //最少允許的列數(shù)
clickToSelect: true, //是否啟用點擊選中行
height: 700, //行高,如果沒有設置height屬性,表格自動根據(jù)記錄條數(shù)覺得表格高度
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) {//偶數(shù)行
strclass = classesArr[0];
} else {//奇數(shù)行
strclass = classesArr[1];
}
return { classes: strclass };
},//隔行變色
});
};
//得到查詢的參數(shù)
oTableInit.queryParams = function (params) {
var temp = { //這里的鍵的名字和控制器的變量名必須一直,這邊改動,控制器也需要改成一樣的
limit: params.limit, //頁面大小
offset:params.offset
};
return temp;
};
return oTableInit;
};
function operateFormatter(value, row, index) {//賦予的參數(shù)
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('');
}
5、后臺url返回數(shù)據(jù)
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);
}
在本文中,博主以匿名集合來設置數(shù)據(jù),大家可以通過查詢數(shù)據(jù)庫獲取數(shù)據(jù)
在此需要注意:返回的參數(shù)必須是total和rows,total返回數(shù)據(jù)集總個數(shù),rows返回table的json格式
6、展示效果

發(fā)現(xiàn)出現(xiàn)了這個bug,這是怎么回事
在瀏覽器上打開源代碼

發(fā)現(xiàn)多了一些其他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文件注釋掉再運行

發(fā)現(xiàn)成功了!這是因為JS庫文件的引用是有順序的,必須先引用JQuery庫文件,再引用插件js
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
javascript 復雜的嵌套環(huán)境中輸出單引號和雙引號
如果簡單的嵌套一般都是外面用雙引號,則里面用單引號,反之亦同,如果特別負責的嵌套大家看下如下的方法。2009-05-05
JavaScript高級程序設計閱讀筆記(五) ECMAScript中的運算符(一)
ECMAScript中的運算符,學習js的朋友可以看看2012-02-02
詳解ES6 export default 和 import語句中的解構賦值
這篇文章主要介紹了詳解ES6 export default 和 import語句中的解構賦值,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-05-05

