bootstrap Table從零開始

来源:http://www.cnblogs.com/baixiaoguang/archive/2017/06/29/7094459.html
-Advertisement-
Play Games

本文博主將從零開始,一步一步的告訴大家如何在前端用bootstrap Table插件展示一個表格 首先,要下載bootstrap Table插件所必須的js,地址:https://github.com/wenzhixin/bootstrap-table 官方文檔地址:http://bootstrap ...


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

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

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

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


 本文需要註意點地方博主已用紅筆圈起來

先展示效果圖

 

 


 

接下來就開始使用bootstrap Table插件製作表格

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

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

本文以MVC為例,當然WebForm也是可以的

使用步驟:

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

2、在視圖裡引用相應的js

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

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

3、初始化bootstrap Table

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

4、使用bootstrap Table

 1 var TableInit = function () {
 2     var oTableInit = new Object();
 3     //初始化Table
 4     oTableInit.Init = function () {
 5         $('#ArbetTable').bootstrapTable({
 6             url: '/Interface/GetData',         //請求後臺的URL(*)
 7             method: 'get',                      //請求方式(*)
 8             toolbar: '#toolbar',                //工具按鈕用哪個容器
 9             striped: true,                      //是否顯示行間隔色
10             cache: false,                       //是否使用緩存,預設為true,所以一般情況下需要設置一下這個屬性(*)
11             pagination: true,                   //是否顯示分頁(*)
12             sortable: false,                     //是否啟用排序
13             sortOrder: "asc",                   //排序方式
14             queryParams: oTableInit.queryParams,//傳遞參數(*)
15             sidePagination: "server",           //分頁方式:client客戶端分頁,server服務端分頁(*)
16             pageNumber: 1,                       //初始化載入第一頁,預設第一頁
17             pageSize: 10,                       //每頁的記錄行數(*)
18             pageList: [10, 25, 50, 100],        //可供選擇的每頁的行數(*)
19             search: true,                       //是否顯示表格搜索,此搜索是客戶端搜索,不會進服務端,所以,個人感覺意義不大
20             contentType: "application/x-www-form-urlencoded",
21             strictSearch: true,
22             showColumns: true,                  //是否顯示所有的列
23             showRefresh: true,                  //是否顯示刷新按鈕
24             minimumCountColumns: 2,             //最少允許的列數
25             clickToSelect: true,                //是否啟用點擊選中行
26             height: 700,                        //行高,如果沒有設置height屬性,表格自動根據記錄條數覺得表格高度
27             uniqueId: "no",                     //每一行的唯一標識,一般為主鍵列
28             showToggle: true,                    //是否顯示詳細視圖和列表視圖的切換按鈕
29             cardView: false,                    //是否顯示詳細視圖
30             detailView: false,                   //是否顯示父子表
31             columns: [
32             {
33                 field: 'ID',
34                 title: 'ID'
35             }, {
36                 field: 'Name',
37                 title: '名字'
38             }, {
39                 field: 'Sex',
40                 title: '性別'
41             },
42             {
43                 field: 'operate',
44                 title: '操作',
45                 formatter: operateFormatter //自定義方法,添加操作按鈕
46             },
47             ],
48             rowStyle: function (row, index) {
49                 var classesArr = ['success', 'info'];
50                 var strclass = "";
51                 if (index % 2 === 0) {//偶數行
52                     strclass = classesArr[0];
53                 } else {//奇數行
54                     strclass = classesArr[1];
55                 }
56                 return { classes: strclass };
57             },//隔行變色
58         });
59 
60     };
61 
62 
63     //得到查詢的參數
64     oTableInit.queryParams = function (params) {
65         var temp = {   //這裡的鍵的名字和控制器的變數名必須一直,這邊改動,控制器也需要改成一樣的
66             limit: params.limit,   //頁面大小
67             offset:params.offset
68         };
69         return temp;
70     };
71     return oTableInit;
72 };
73 
74 
75 function operateFormatter(value, row, index) {//賦予的參數
76     return [
77         '<a class="btn active disabled" href="#">編輯</a>',
78         '<a class="btn active" href="#">檔案</a>',
79         '<a class="btn btn-default" href="#">記錄</a>',
80         '<a class="btn active" href="#">準入</a>'
81     ].join('');
82 }

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

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.今天申請搭建了自己的雲虛擬主機 2.有挺多疑問:它只能使用ftp傳入主頁或者網站網頁內容嗎?沒有後臺代碼之類的怎麼實現程式的功能調用? ...
  • 最近在搞一個人臉識別的功能,使用了微軟的認知服務,一下講一個我遇到的小問題。 首先添加相關相應的NuGet:Microsoft.ProjectOxford.Face 然後構造FaceServiceClient並調用DetectAsync方法識別人臉信息。 構造FaceServiceClient需要一 ...
  • 引言大家好像對分析源碼厭倦了,說實在我也會厭倦,不過不看是無法分析其後面的東西,從易到難是一個必要的過程。今天說下EventBus,前幾天園裡的大神已經把其解刨,我今天就藉著大神的肩膀,分析下在eShop項目中EventBus的實現。最近發覺轉發文章不寫出處的,特此加上鏈接:http://inday... ...
  • 代碼: using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Net; using System.Text; namespace SunCreate.Comba ...
  • 代碼: <Grid> <Grid> <Grid.ColumnDefinitions> <ColumnDefinition Width="3*" /> <ColumnDefinition Width="2*" /> <ColumnDefinition Width="2*"/> <ColumnDefin ...
  • 引用DLL: WPFToolkit WPFVisifire.Charts.dll WPFVisifire.Gauges.dll 1、柱狀圖 代碼: public void BindChart1() { List<string> colorList = new List<string>(); List ...
  • 一、擴展方法的語法 在視圖中使用擴展方法的時候 如果擴展方法定義的類在其他命名空間,需要首先引用該命名空間,才能使用該擴展方法 static class 靜態類名 { static 返回類型 擴展方法名(this 擴展的類型 對象名,[其他參數列表]) { //擴展方法代碼 } } eg1:給Str ...
  • 一。關於安裝 1.可以直接通過vs自帶的Nuget包管理器來搜索下載,直接搜索“NLog”: 註意,除了要安裝第一個之外,一定要安裝“NLog.Config”,否則無法在項目中正常使用NLog的配置文件。 二。配置NLog。 1.打開NLog.config文件,在<targets>標簽內加入對應的日 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...