bootstrap Table的 一些小操作

来源:http://www.cnblogs.com/tzzf/archive/2017/10/31/7764360.html
-Advertisement-
Play Games

前端分頁的Table配置函數 根據每行數據的一個欄位的值來改變行的背景色(class好像只能調用他本來預設的那幾個,很久之前寫的忘記了是不是這樣的) 這個是根據每行數據的一個欄位的值來是否禁用選擇框(我在之前項目需要做結算,已結算的和未結算的在一起,因此需要這個),formatter還可以寫別的函數 ...


function HQCreatTable(ob) {
    var option = {
        cache: false,//是否使用緩存,預設為true,所以一般情況下需要設置一下這個屬性(*)
        scrollX: true,
        scrollY:true,
        striped: true,     //使表格帶有條紋 //是否顯示行間隔色
        sidePagination: "client",//分頁方式:client客戶端分頁,server服務端分頁(*)
        pagination: true,    //在表格底部顯示分頁工具欄
        pageNumber: 1,   //初始化載入第一頁,預設第一頁
        pageSize: 10,
        pageList: [ 10,15],//可供選擇的每頁的行數(*)
        showColumns: false,//是否顯示所有的列
        sortable: true, //是否啟用排序
        
        clickToSelect: true,//是否啟用點擊選中行
        showRefresh: false,  //顯示刷新按鈕
        //search: false,//是否顯示右上角的搜索框
        //toolbar: '#toolbar', //工具按鈕用哪個容器
        uniqueId: "ID", //每一行的唯一標識,一般為主鍵列
        undefinedText: "",
        toolbarAlign: 'left',
        exportDataType: "all", //basic', 'all', 'selected'.
    }
    if (ob.rowStyle) {
        option.rowStyle = ob.rowStyle;//行樣式 是函數
    }
    //排序
    if (ob.sortOrder) {
        option.sortOrder = ob.sortOrder;
    } else {
        option.sortOrder = "desc";
    }
    if (ob.sortName) {
        option.sortName = ob.sortName;
    }
    if (ob.showExport) {
        option.showExport = ob.showExport;//導出Excel
    }
    if (ob.showFooter) {
        option.showFooter = ob.showFooter;//是否顯示統計頁腳
    }
    if (ob.searchAlign) {
        option.searchAlign = ob.searchAlign;
    }
    if (ob.num) {
        option.pageSize = ob.num;//每頁的記錄行數(*)
    }
    if (ob.data) {
        option.data = ob.data;
    } else {
        option.data = [];
    }
    if (ob.search) {
        option.search = ob.search;
    }
    if (ob.columns) {
        option.columns = ob.columns;
    }
    if (ob.onClickRow) {
        option.onClickRow = ob.onClickRow;
    }
    if (ob.onDblClickRow) {
        option.onDblClickRow = ob.onDblClickRow;
    }
    if (ob.onDblClickRow) {
        option.onDblClickRow = ob.onDblClickRow;
    }
    if (ob.onCheck) {
        option.onCheck = ob.onCheck;
    }
    if (ob.onAll) {
        option.onAll = ob.onAll;
    }
    if (ob.onLoadSuccess) {
        option.onLoadSuccess = ob.onLoadSuccess;
    }
    if (ob.toolbar) {
        option.toolbar = ob.toolbar;
    }
    if (ob.singleSelect || ob.singleSelect == false) {
        option.singleSelect = ob.singleSelect
    } else {
        option.singleSelect = true;//禁止多選
    }
    if (ob.maintainSelected) {
        option.maintainSelected = ob.maintainSelected;
    } else {
        option.maintainSelected = false;//設置為 true 在點擊分頁按鈕或搜索按鈕時,將記住checkbox的選擇項
    }
    if (ob.detailView) { option.detailView = ob.detailView; }
    if (ob.onExpandRow) {
        option.onExpandRow = ob.onExpandRow;
    }
    if (ob.onEditableSave) {
        option.onEditableSave = ob.onEditableSave;
    }
    $(ob.id).bootstrapTable('destroy');
    $(ob.id).bootstrapTable(option);
    if (ob.data) {
        $(ob.id).bootstrapTable('load', ob.data);
    }
}

前端分頁的Table配置函數

<table id="Table3" data-row-style="rowStyle"></table>
 //行根據數據變色
    function rowStyle(row, index) {
        var classes = ['success'];
        var classes1 = ['danger'];
        var classes2 = ['warning'];
        if (row.bed_msg==0) {
            return {
                classes: classes2
            };
        }else{
            if (row.status == 1) {
                return {
                    classes: classes1
                };
            } else {
                    return {
                classes: classes
                };
            }
        }
        
    }

根據每行數據的一個欄位的值來改變行的背景色(class好像只能調用他本來預設的那幾個,很久之前寫的忘記了是不是這樣的)

formatter: function (value, row, index) {
                    // 根據row.列名   那狀態確定返回 true/false
                    if (row.status == 1) {
                        return {
                            disabled: true
                        };
                    }
                    
                }

這個是根據每行數據的一個欄位的值來是否禁用選擇框(我在之前項目需要做結算,已結算的和未結算的在一起,因此需要這個),formatter還可以寫別的函數,比如根據1,0值改成其對應的值

footerFormatter: function (data) {
                          return data.reduce(function (sum, row) {
                              return accAdd(sum, row["Selmoney"]);
                          }, 0) + "";
                      }
footerFormatter是必須之前的配置Table時,showFooter屬性為true,否則不會顯示。我寫這個是前端分頁的話是Table所有數據的Selmoney值的總和,後端分頁的話則是當頁數據的總和。

 


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

-Advertisement-
Play Games
更多相關文章
  • 今天在調試bug的時候有一個需求,我需要知道我的代碼中有哪些地方在修改body的style,然後我想到了DOM節點監聽。 為body添加斷點然後開始調試,但是現在的前端技術棧太複雜,即使打了斷點也會跳進第三方包里。調用棧里有太多無關的js代碼,妨礙調試。 所以你可以選中文件右擊後,選擇Blackbo ...
  • 在開發的過程中,幾乎不可能一次性就能寫出毫無破綻的程式,斷點調試代碼是一個普遍的需求。 作為前端開發工程師,以往我們開發的JavaScript程式都運行在瀏覽器端,利用Chrome提供的開發者工具就可以方便的進行源碼斷點調試。其步驟有四,詳情不表,粗略概括如下: 但是,當我們用JavaScript開 ...
  • 控制項概述 Google Maps 上的地圖包含用戶界面元素,可以讓用戶通過地圖進行交互。這些元素稱為“控制項”。您可以在 Google Maps API 應用程式中添加這些控制項的多種組合。或者,您也可以不進行任何操作,讓 Google Maps API 處理所有控制項行為。 Google Maps AP ...
  • /** 日期格式化 */Date.prototype.Format = function(format) { var o = { "M+" : this.getMonth() + 1, // month "d+" : this.getDate(), // day "H+" : this.getHou ...
  • z 品牌:騰訊案例地址:http://www.199case.com/caseview.aspx?id=624 來源:199case_H5案例庫 1、內容:通過首頁的js動態按鈕進入下一界面,整個過程橫屏設置,採用了拍攝好的完整多骨諾視頻,並且在視頻的不同節點出現相應文字,可以鮮明和充分的展現TEG ...
  • 品牌:保時捷 案例地址:http://www.199case.com/caseview.aspx?id=2875 來源:199case-H5案例庫 1、內容:一個以”捕捉迅疾魅影“為主題的聲音識別類的h5,用戶可以通過聽取最大的跑車的引擎聲,然後點擊相機狀的按鈕,即可拍攝成功,最後展示類保時捷的跑車 ...
  • 複習作用域 上一節我們說到作用域:是指變數可以訪問的範圍,他規定瞭如何查找變數,以及確定當前執行代碼對變數的訪問許可權;也說到靜態作用域即詞法作用域,是在編譯階段決定變數的引用(由程式定義的位置決定,和代碼執行順序無關,用嵌套的方式解析)。 凝問 如上代碼,在執行run函數時,在run作用域中有nam ...
  • 實現效果: 實現原理: // 步驟 // 1. 獲取事件源以及相關元素 // 2. 複製第一張圖片所在的li,添加到ul的最後面 // 3. 給ol添加li,ul中的個數-1個,並點亮第一個按鈕 // 4. 滑鼠放到ol的li上切換圖片 // 5. 添加定時器 // 6. 左右切換圖片(滑鼠放上去隱 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...