本文小編將帶大家從零開始,一步一步的告訴大家如何在前端用bootstrap Table插件展示一個表格
首先,要下載bootstrap Table插件所必須的js,地址:https://github.com/wenzhixin/bootstrap-table
官方文件地址:http://bootstrap-table.wenzhixin.net .cn/zh-cn/documentation/
推薦教學:#bootstrap教學
本文需要注意點地方小編已用紅筆圈起來
先展示效果圖
#接下來就開始使用bootstrap Table外掛程式製作表格
將上述位址下載的外掛程式js放到專案中,分別為js,css,fonts
這裡有一個細節: 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,//传递参数(*) 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(''); }
4、後台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格式
##5、展示效果發現出現了這個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
以上是bootstrap Table從零開始的詳細內容。更多資訊請關注PHP中文網其他相關文章!