本篇文章為大家展示了什么是Bootstrap Table API 中文版,代碼簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
成都創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比鋼城網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式鋼城網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋鋼城地區(qū)。費(fèi)用合理售后完善,10余年實(shí)體公司更值得信賴。看網(wǎng)上有中文版的,但有些就是字面直接譯過來了,而且有的就沒有翻譯,那就打算自己再翻譯一遍,每一條會盡大可能結(jié)合盡可能多資料翻譯,如果發(fā)現(xiàn)譯的內(nèi)容比英文多,是添加了更詳細(xì)的說明,表的名稱,屬性,類型,默認(rèn)值不翻譯,例如:"class"、"id"等不翻譯。有錯(cuò)請?zhí)岢?,會及時(shí)改正,謝謝。
1、“名稱”可以寫在$('#table').bootstrapTable({});的大括號中,可以定義一些想要的值,如:
$("#realTime_Table").bootstrapTable({ search: true, pagination: false, pageSize: 15, pageList: [5, 10, 15, 20], showColumns: true, showRefresh: false, showToggle: true, locale: "zh-CN", striped: true });
2、“屬性”放在聲明表內(nèi),如:
日期 | 新增用戶 | 活躍用戶 |
---|
3、如果名稱和屬性功能類似,則任意一個(gè)地方就夠了,不用重復(fù)定義,有的屬性寫在js里比名稱寫在聲明表中更為簡單,or vice verse(有的屬性必須要寫,對應(yīng)的名稱只是表示是否啟用那個(gè)屬性)
表的各項(xiàng)(Table options )
名稱 | 屬性 | 類型 | 默認(rèn)值 | 作用描述 |
---|---|---|---|---|
- | data-toggle | String | table | 只要引入 jquery、bootstrap 、bootstrap-table的包,不用在js里面定義就可以使用 默認(rèn)有寫data-toggle="table",data-toggle應(yīng)該知道吧,常用的有"tooltip、popover等等",這邊就不說了 |
classes | data-classes | String | table table-hover | 表的class屬性,如果沒有自己定義,則默認(rèn)有邊框,并且當(dāng)鼠標(biāo)懸浮在那一行,背景會變?yōu)闇\灰色. |
sortClass | data-sort-class | String | undefined | 聲明表格td的class名,代表此列元素的class名將被排序 |
height | data-height | Number | undefined | 表格的高度 |
undefinedText | data-undefined-text | String | - | 當(dāng)不寫任何內(nèi)容默認(rèn)顯示'-' |
striped | data-striped | Boolean | false | 默認(rèn)false,當(dāng)設(shè)為true,則每行表格的背景會顯示灰白相間 |
sortName | data-sort-name | String | undefined | 定義哪一列的值會被排序,寫data-field的自定義名,沒定義默認(rèn)都不排列,同下面的sortOrder結(jié)合使用,沒寫的話列默認(rèn)遞增(asc) |
sortOrder | data-sort-order | String | asc | 同上面的結(jié)合使用,默認(rèn)遞增(asc),也可設(shè)為遞減(desc) |
sortStable | data-sort-stable | Boolean | false | (別看錯(cuò)了,是sortStable,sortable在下面)默認(rèn)false,設(shè)為true,則和sort部分一樣,區(qū)別是:在排序過程中,如果存在相等的元素,則原來的順序不會改變。原文還有一句:(如果你把此屬性設(shè)為了true)我們將為此行添加'_position'屬性 |
iconsPrefix | data-icons-prefix | String | glyphicon | 定義字體庫 ('Glyphicon' or 'fa' for FontAwesome),使用"fa"時(shí)需引用 FontAwesome,并且配合 icons 屬性實(shí)現(xiàn)效果 Glyphicon 集成于Bootstrap可免費(fèi)使用 |
iconSize | data-icon-size | String | undefined | 定義的圖標(biāo)大?。?br/>
- undefined =>默認(rèn)表示默認(rèn)的按鈕尺寸(btn) - xs =>超小按鈕的尺寸(btn-xs) - sm =>小按鈕的尺寸(btn-sm) - lg =>大按鈕的尺寸(btn-lg) |
buttonsClass | data-buttons-class | String | default | 按鈕的類,默認(rèn)為default。 - 可選的有:primary、danger、warning等等 - 寫了之后會自動轉(zhuǎn)換為btn-primary(藍(lán)色)、btn-danger(紅色)、btn-warning(黃色)等格式,所以前面不要再加"btn-",默認(rèn)為btn-default(白色) - 參考菜鳥教程:Bootstrap 按鈕 |
icons | data-icons | Object | {
paginationSwitchDown: 'glyphicon-collapse-down icon-chevron-down', paginationSwitchUp: 'glyphicon-collapse-up icon-chevron-up', refresh: 'glyphicon-refresh icon-refresh', toggle: 'glyphicon-list-alt icon-list-alt', columns: 'glyphicon-th icon-th', detailOpen: 'glyphicon-plus icon-plus', detailClose: 'glyphicon-minus icon-minus' } | 定義在工具欄、分頁、詳細(xì)視圖中使用的圖標(biāo) - 沒辦法解釋,請參考菜鳥教程的圖標(biāo):Bootstrap 字體圖標(biāo) |
columns | - | Array | [] | 默認(rèn)空數(shù)組,在JS里面定義,field即data-field,title就是每列表頭名等等。 - 請參考:查Bootstrap-table的Usage |
data | - | Array | [] | 被加載的數(shù)據(jù)。 - 也就是從服務(wù)器獲取的數(shù)據(jù),通過"."運(yùn)算符獲取,例如"data.date/data.anything",后面是服務(wù)器發(fā)來的字段名 |
dataField | data-data-field | String | rows | - 名稱寫自己定義的每列的字段名,也就是key,通過key才能給某行的某列賦value。 - 原文:獲取每行數(shù)據(jù)json內(nèi)的key - 例如:{"name":"zz","age":20},name和age就是key,如果這是從服務(wù)端請求的json,那可能和每列定義的字段不同,但都是唯一的 |
ajax | data-ajax | Function | undefined | - ajax方法,和jQuery的ajax方法類似 |
method | data-method | String | get | 向服務(wù)器請求遠(yuǎn)程數(shù)據(jù)的方式,默認(rèn)為'get',可選'post' |
url | data-url | String | undefined | 向服務(wù)器請求的url。 - 例如:server + "get_app_player"和server + 'get_channel_list',兩者都是向server(server是自己定義的,例如"http://kanshakan.nichousha.com/")請求數(shù)據(jù),只是接口不同,一個(gè)是請求該游戲玩家信息,一個(gè)是請求渠道信息 下面看看原文: - 向遠(yuǎn)程站點(diǎn)請求數(shù)據(jù)的URL - 請記住,如果服務(wù)端分頁選項(xiàng)使用了自定義的,那么請求的服務(wù)器響應(yīng)格式是不同的,參考下面兩個(gè)數(shù)據(jù)格式: Without server-side pagination(沒有啟用服務(wù)端分頁 - data1.json) With server-side pagination(啟用服務(wù)端分頁 - data2.json) |
cache | data-cache | Boolean | true | 默認(rèn)緩存ajax請求,設(shè)為false則禁用緩存 |
contentType | data-content-type | String | application/json | 請求數(shù)據(jù)的contentType(內(nèi)容類型),用于定義文件的類型,決定接收方以什么形式讀取這個(gè)文件。 - 默認(rèn)application/json,用來告訴接收端從服務(wù)器發(fā)來的消息是序列化后的json字符串 |
dataType | data-data-type | String | json | 期望從服務(wù)器獲取的數(shù)據(jù)的類型,默認(rèn)為json格式字符串 |
ajaxOptions | data-ajax-options | Object | {} | 向服務(wù)器請求ajax時(shí)的附加項(xiàng),默認(rèn)無附加 - 參考 jQuery.ajax() |
queryParams | data-query-params | Function | function(params){ return params;} | 當(dāng)請求數(shù)據(jù)時(shí),你可以通過修改queryParams向服務(wù)器發(fā)送其余的參數(shù)。 - queryParamsType="limit",它的參數(shù)包括:limit,offset,search,sort,order Else - params包括:pageSize,pageNumber,searchText,sortName,sortOrder - 當(dāng)return false,請求則終止 |
queryParamsType | data-query-params-type | String | limit | 默認(rèn)"limit",設(shè)置該屬性用來發(fā)送符合RESTful格式的參數(shù) |
responseHandler | data-response-handler | Function | function(res){ return res;} | 在加載服務(wù)器發(fā)送來的數(shù)據(jù)之前,處理數(shù)據(jù)的格式,參數(shù)res表示the response data(獲取的數(shù)據(jù)) |
pagination | data-pagination | Boolean | false | 默認(rèn)為false,表格的底部工具欄不會顯示分頁條(pagination toolbar),可以設(shè)為true來顯示 |
paginationLoop | data-pagination-loop | Boolean | true | 默認(rèn)true,分頁條無限循環(huán) |
onlyInfoPagination | data-only-info-pagination | Boolean | false | 前提:pagination設(shè)為true,啟用了分頁功能。 - 默認(rèn)false,設(shè)為true顯示總記錄數(shù) |
sidePagination | data-side-pagination | String | client | 設(shè)置在哪進(jìn)行分頁,默認(rèn)"client",可選"server",如果設(shè)置 "server",則必須設(shè)置url或者重寫ajax方法 - 請記住,如果服務(wù)端分頁選項(xiàng)使用了自定義的,那么請求的服務(wù)器響應(yīng)格式是不同的,參考下面兩個(gè)數(shù)據(jù)格式: Without server-side pagination(沒有啟用服務(wù)端分頁) With server-side pagination(啟用服務(wù)端分頁) |
pageNumber | data-page-number | Number | 1 | 前提:pagination設(shè)為true,啟用了分頁功能。 - 默認(rèn)第1頁,用于設(shè)置初始的頁數(shù) |
pageSize | data-page-size | Number | 10 | 前提:pagination設(shè)為true,啟用了分頁功能。 - 默認(rèn)每頁顯示10條記錄,用于設(shè)置每頁初始顯示的條數(shù) |
pageList | data-page-list | Array | [10, 25, 50, 100] | 前提:pagination設(shè)為true,啟用了分頁功能。 - 默認(rèn)為[10, 25, 50, 100],即可以選擇"每頁顯示10/25/50/100條記錄",用于設(shè)置選擇每頁顯示的條數(shù) |
selectItemName | data-select-item-name | String | btSelectItem | radio(單選按鈕)或checkbox(復(fù)選框)的字段名 |
smartDisplay | data-smart-display | Boolean | true | 默認(rèn)為true,會根據(jù)情況顯示分頁(pagination)或卡片視圖(card view) |
escape | data-escape | Boolean | false | 跳過插入HTML中的字符串,替換掉特殊字符(后面符號沒有逗號):&,<,>,",`,' |
search | data-search | Boolean | false | 默認(rèn)false不顯示表格右上方搜索框 ,可設(shè)為true,在搜索框內(nèi)只要輸入內(nèi)容即開始搜索 |
searchOnEnterKey | data-search-on-enter-key | Boolean | false | 默認(rèn)false不啟用,設(shè)為true啟用,比功能是與上面相比,在搜索框內(nèi)輸入內(nèi)容并且按下回車鍵才開始搜索 |
strictSearch | data-strict-search | Boolean | false | 設(shè)為true,開啟精確搜索 |
searchText | data-search-text | String | "" | 前提:search設(shè)為true,啟用了搜索功能。 - 搜索框初始顯示的內(nèi)容,默認(rèn)空字符串 |
searchTimeOut | data-search-time-out | Number | 500 | 前提:search設(shè)為true,啟用了搜索功能。 - 設(shè)置搜索文件的超時(shí)時(shí)間(原文:Set timeout for search fire,不知道是寫錯(cuò)了還是我知識面太窄,"search fire"是什么意思,官方API錯(cuò)了?給我整蒙逼了) |
trimOnSearch | data-trim-on-search | Boolean | true | 默認(rèn)true,自動忽略空格 |
showHeader | data-show-header | Boolean | true | 默認(rèn)為true顯示表頭,設(shè)為false隱藏 |
showFooter | data-show-footer | Boolean | false | 默認(rèn)為false隱藏表尾,設(shè)為true顯示 |
showColumns | data-show-columns | Boolean | false | 默認(rèn)為false隱藏某列下拉菜單,設(shè)為true顯示 |
showRefresh | data-show-refresh | Boolean | false | 默認(rèn)為false隱藏刷新按鈕,設(shè)為true顯示 |
showToggle | data-show-toggle | Boolean | false | 默認(rèn)為false隱藏視圖切換按鈕,設(shè)為true顯示 |
showPaginationSwitch | data-show-pagination-switch | Boolean | false | 默認(rèn)為false隱藏每頁數(shù)據(jù)條數(shù)選擇,設(shè)為true顯示 |
minimumCountColumns | data-minimum-count-columns | Number | 1 | 每列的下拉菜單最小數(shù) |
idField | data-id-field | String | undefined | 表明哪個(gè)是字段是標(biāo)識字段 |
uniqueId | data-unique-id | String | undefined | 表明每行唯 一的標(biāo)識符 |
cardView | data-card-view | Boolean | false | 默認(rèn)false,設(shè)為true顯示card view(卡片視圖) |
detailView | data-card-view | Boolean | false | 默認(rèn)false,設(shè)為true顯示detail view(細(xì)節(jié)視圖) |
detailFormatter | data-detail-formatter | Function | function(index, row, element){ return '';} | 前提:detailView設(shè)為true,啟用了顯示detail view。 - 用于格式化細(xì)節(jié)視圖 - 返回一個(gè)字符串,通過第三個(gè)參數(shù)element直接添加到細(xì)節(jié)視圖的cell(某一格)中,其中,element為目標(biāo)cell的jQuery element |
searchAlign | data-search-align | String | right | 搜索框的位置,默認(rèn)right(最右),可選left |
buttonsAlign | data-buttons-align | String | right | 工具欄按鈕的位置,默認(rèn)right(最右),可選left |
toolbarAlign | data-toolbar-align | String | left | 自定義工具欄的位置,默認(rèn)right(最右),可選left |
paginationVAlign | data-pagination-v-align | String | bottom | 分頁條垂直方向的位置,默認(rèn)bottom(底部),可選top、both(頂部和底部均有分頁條) |
paginationHAlign | data-pagination-h-align | String | right | 分頁條水平方向的位置,默認(rèn)right(最右),可選left |
paginationDetailHAlign | data-pagination-detail-h-align | String | left | 如果解譯的話太長,舉個(gè)例子,paginationDetail就是“顯示第 1 到第 8 條記錄,總共 15 條記錄 每頁顯示 8 條記錄”,默認(rèn)left(最左),可選right |
paginationPreText | data-pagination-pre-text | String | ? | 還是舉例子,如果你內(nèi)容太多,底部最右邊會顯示:"? 1 2 3 4 5 ?"來選擇頁數(shù),默認(rèn)就是最左邊那個(gè)符號,下同 |
paginationNextText | data-pagination-next-text | String | ? | 參考上面一條 |
clickToSelect | data-click-to-select | Boolean | false | 默認(rèn)false不響應(yīng),設(shè)為true則當(dāng)點(diǎn)擊此行的某處時(shí),會自動選中此行的checkbox(復(fù)選框)或radiobox(單選按鈕) |
singleSelect | data-single-select | Boolean | false | 默認(rèn)false,設(shè)為true則允許復(fù)選框僅選擇一行 |
toolbar | data-toolbar | String | Node | undefined | jQuery的選擇器,例如:#toolbar,.toolbar,或者是DOM 結(jié)點(diǎn) |
checkboxHeader | data-checkbox-header | Boolean | true | 如果你有聲明復(fù)選框,默認(rèn)顯示表頭行的全選復(fù)選框,設(shè)為false隱藏(就是表格第一行的不顯示,從第二行往后都顯示) |
maintainSelected | data-maintain-selected | Boolean | false | 設(shè)為true則保持被選的那一行的狀態(tài) |
sortable | data-sortable | Boolean | true | 默認(rèn)true,設(shè)為false禁用所有的行排列(也就是每列表頭不會顯示排序的按鈕,這個(gè)需要在th聲明data-sortable="true",寫在js中只是啟不啟用) |
slientSort | data-silent-sort | Boolean | true | 前提:sidePagination設(shè)為server(服務(wù)端) - 默認(rèn)true,設(shè)為false則靜默排序數(shù)據(jù) |
rowStyle | data-row-style | Function | {} | 改變某行的格式,需要兩個(gè)參數(shù):
- row:此行的數(shù)據(jù) - index:此行的索引 支持classes和css,用法如下: function rowStyle(row, index){ return { classes: 'text-nowrap another-class', css: {"color": "blue", "font-size": "50px"} }; } |
rowAttributes | data-row-attributes | Function | {} | 改變某行的屬性,需要兩個(gè)參數(shù): - row:此行的數(shù)據(jù) - index:此行的索引 支持所有自定義的屬性。 |
customSearch | data-custom-search | Function | $.noop | 自定義搜索功能(用來代替自帶的搜索功能),需要一個(gè)參數(shù): - text:想要搜索的內(nèi)容 用法如下: function customSearch(text){ //必須使用'this.data'對數(shù)據(jù)進(jìn)行過濾(filter the data,感覺這個(gè)詞也不用譯),不要使用'this.options.data' } |
customSort | data-custom-sort | Function | $.noop | 自定義排序功能(用來代替自帶的排序功能),需要兩個(gè)參數(shù)(可以參考前面): - sortName:需要排序的那列 - sortOrder:排序方式 用法:和上面一樣,不用擔(dān)心,注釋也一模一樣 |
locale | data-locale | String | undefined | 本地化(動詞)。 本地化的文件必須被預(yù)加載,允許fallback(簡單來說就是如果要使用的文件不可用,就可以用別的替代它,例如球場替補(bǔ),沒替補(bǔ),如果有人受傷了,比賽不就廢了),如果加載,將按如下順序: - 首先嘗試加載的是指定的"本地化"文件 - 然后是'_'(下劃線)寫成'-'(破折號),并且區(qū)域代碼被大寫的 - 然后是短區(qū)域代碼(例如:用'fr'代替'fr-CA') - 最后使用的是剩下的本地化文件(當(dāng)沒有文件可加載則使用默認(rèn)的) 如果剩余的undefined,或者是空字符,則使用最后一次使用的那個(gè)文件(當(dāng)沒有本地化文件可被加載,則使用自帶的'en_US') |
footerStyle | data-footer-style | Function | {} | 改變footer格式,需要兩個(gè)參數(shù):
- row:此行的數(shù)據(jù) - index:此行的索引 支持classes和css,用法如下: function rowStyle(value,row, index){ return { css: { "font-weight": "bold" } }; } |
列的各項(xiàng)(Column options )
名稱 | 屬性 | 類型 | 默認(rèn)值 | 作用描述 | |
---|---|---|---|---|---|
radio | data-radio | Boolean | false | 默認(rèn)false不顯示radio(單選按鈕),設(shè)為true則顯示,radio寬度是固定的 | |
checkbox | data-checkbox | Boolean | false | 默認(rèn)false不顯示checkbox(復(fù)選框),設(shè)為true則顯示,checkbox的每列寬度已固定 | |
field | data-field | String | undefined | 是每列的字段名,不是表頭所顯示的名字,通過這個(gè)字段名可以給其賦值,相當(dāng)于key,表內(nèi)唯一 | |
title | data-title | String | undefined | 這個(gè)是表頭所顯示的名字,不唯一,如果你喜歡,可以把所有表頭都設(shè)為相同的名字 | |
titleTooltip | data-title-tooltip | String | undefined | 當(dāng)懸浮在某控件上,出現(xiàn)提示 - 參考 Bootstrap 提示工具(Tooltip)插件 | |
class | class/data-class | String | undefined | 沒什么好說的,就是class | |
rowspan | rowspan/data-rowspan | Number | undefined | 每格所占的行數(shù) | |
colspan | colspan/data-colspan | Number | undefined | 每格所占的列數(shù) | |
align | data-align | String | undefined | 每格內(nèi)數(shù)據(jù)的對齊方式,有:left(靠左)、right(靠右)、center(居中) | |
halign | data-halign | String | undefined | table header(表頭)的對齊方式,有:left(靠左)、right(靠右)、center(居中) | |
falign | data-falign | String | undefined | table footer(表腳,就這樣譯,任性,其實(shí)隨便譯啦,知道就好)的對齊方式,有:left(靠左)、right(靠右)、center(居中) | |
valign | data-valign | String | undefined | 每格數(shù)據(jù)的對齊方式,有:top(靠上)、middle(居中)、bottom(靠下) | |
width | data-width | Number(單位:px或%) | undefined | 每列的寬度。 - 如果沒有自定義寬度,那么寬度會根據(jù)內(nèi)容的寬度自適應(yīng)。 - 如果表是左適應(yīng)(left responsive)或者設(shè)置的寬度小于內(nèi)容的寬度,那么,寬度還是會自適應(yīng)(可以在class或其他的屬性中使用 min-width 或 max-width)。 - 你也可以使用"%"作為單位,這樣的話,bootstapTable將按百分比劃分,如果你想使用"pixels(像素值)",你可以只寫數(shù)字(只要不加"%",單位默認(rèn)"px",不嫌麻煩,或者想更清晰,你也可以加上"px") | |
sortable | data-sortable | Boolean | false | 默認(rèn)false就默認(rèn)顯示,設(shè)為true則會被排序 | |
order | data-order | String | asc | 默認(rèn)的排序方式為"asc(升序)",也可以設(shè)為"desc(降序)"。 - 與上面的結(jié)合使用,不然都不讓排序了,你還考慮什么升降。 | |
visible | data-visible | Boolean | true | 默認(rèn)為true顯示該列,設(shè)為false則隱藏該列。 - 還是很有用的,例如隱藏自定義index列,按某屬性排序后會變亂,你可以讀取某行的index來進(jìn)行賦值 | |
cardVisible | data-card-visible | Boolean | true | 默認(rèn)為true顯示該列,設(shè)為false則隱藏。 | |
switchable | data-switchable | Boolean | true | 默認(rèn)為true顯示該列,設(shè)為false則禁用列項(xiàng)目的選項(xiàng)卡。 | |
clickToSelect | data-click-to-select | Boolean | true | 默認(rèn)true不響應(yīng),設(shè)為false則當(dāng)點(diǎn)擊此行的某處時(shí),不會自動選中此行的checkbox(復(fù)選框)或radiobox(單選按鈕) | |
formatter | data-formatter | Function | undefined | 需要此列的對象。 某格的數(shù)據(jù)轉(zhuǎn)換函數(shù),需要三個(gè)參數(shù): -value: field(字段名) -row:行的數(shù)據(jù) -index:行的(索引)index | |
footerFormatter | data-footer-formatter | Function | undefined | 需要此列的對象。 某格的數(shù)據(jù)轉(zhuǎn)換函數(shù),需要一個(gè)參數(shù): -data: 所有行數(shù)據(jù)的數(shù)組 函數(shù)需要返回(return)footer某格內(nèi)所要顯示的字符串的格式,還要包括內(nèi)容 | |
events | data-events | Object | undefined | 當(dāng)某格使用formatter函數(shù)時(shí),事件監(jiān)聽會響應(yīng),需要四個(gè)參數(shù): -event:jQuery事件(參考Events)。 - value:字段名 - row:行數(shù)據(jù) - index:此行的index 舉個(gè)例子: | var operateEvents = {'click .like': function (e, value, row, index) {}}; |
sorter | data-sorter | Function | undefined | 自定義的排序函數(shù),實(shí)現(xiàn)本地排序,需要兩個(gè)參數(shù): - a:第一個(gè)字段名 - b:第二個(gè)字段名 | |
sortName | data-sort-name | String | undefined | 除了表頭默認(rèn)的sort-name或列的字段名,還可以使用自定義的sort-name 對特殊情況說明: - 一個(gè)列顯示的內(nèi)容或許是"html"代碼,如:abc,但是被排列的是html代碼中的內(nèi)容(content):abc | |
cellStyle | data-cell-style | Function | undefined | 對某格中顯示樣式(style)進(jìn)行改變,需要三個(gè)函數(shù): - value:字段名 - row:行數(shù)據(jù) - index:此行的index - field:行的字段名 支持classes和css,用法如下: function cellStyle(value, row, index, field) { return { classes: 'text-nowrap another-class', css: {"color": "blue", "font-size": "50px"} }; } | |
searchable | data-searchable | Boolean | true | 默認(rèn)true,表示此列數(shù)據(jù)可被查詢 | |
searchFormatter | data-search-formatter | Boolean | true | 默認(rèn)true,可使用格式化的數(shù)據(jù)查詢 | |
escape | data-escape | Boolean | false | 跳過插入HTML中的字符串,替換掉特殊字符(后面符號沒有逗號):&,<,>,",`,' |
事件(Events)
定義事件的格式: $(’#table’).bootstrapTable({ onEventName: function (arg1, arg2, …) { // … } }); $(’#table’).on(‘event-name.bs.table’, function (e, arg1, arg2, …) { // … });
事件名 | 定義在jQuery中的事件名 | 參數(shù) | 作用描述 |
---|---|---|---|
onAll | all.bs.table | name, args | 當(dāng)所有觸發(fā)器被觸發(fā)時(shí)都執(zhí)行此函數(shù),就是所有的事件都會觸發(fā)該事件,參數(shù)包括: - name:事件名 - args:事件的數(shù)據(jù) |
onClickRow | click-row.bs.table | row, $element, field | 當(dāng)單擊此行的任意一處,就會觸發(fā)該事件,所需參數(shù)如下(只是按原文譯過來的,在bootstraptable的js中不需要這些參數(shù),因?yàn)閱螕粼撔芯蜁@得一個(gè)row,row中包括此行所有數(shù)據(jù),只要通過此行某列的字段名即可取出): - row:哪一行(從0開始) - $element:該行(tr) - field:當(dāng)點(diǎn)擊該行,你想獲取此行哪一格的數(shù)據(jù),field就是此列字段名 |
onDblClickRow | dbl-click-row.bs.table | row, $element, field | 和上面差不多,當(dāng)雙擊(666)此行的任意一處,就會觸發(fā)該事件,所需參數(shù)如下(只是按原文譯過來的,在bootstraptable的js中不需要這些參數(shù),因?yàn)殡p擊該行就會獲得一個(gè)row,row中包括此行所有數(shù)據(jù),只要通過此行某列的字段名即可取出): - row:哪一行(從0開始) - $element:該行(tr) - field:當(dāng)點(diǎn)擊該行,你想獲取此行哪一格的數(shù)據(jù),field就是此列字段名 |
onClickCell | click-cell.bs.table | field, value, row, $element | 當(dāng)單擊某一格,就會觸發(fā)該事件,所需參數(shù)如下: - field:此格所在列的字段名 - value:此格的數(shù)據(jù) - $element:此行的此列,就是此格(td) |
onDblClickCell | dbl-click-cell.bs.table | field, value, row, $element | 當(dāng)雙擊某一格,就會觸發(fā)該事件,所需參數(shù)如下: - field:此格所在列的字段名 - value:此格的數(shù)據(jù) - $element:此行的此列,就是此格(td) |
onSort | sort.bs.table | name, order | 當(dāng)對某列進(jìn)行排序時(shí)觸發(fā)該事件,所需參數(shù)如下: - name:所排序的列的字段名 - order:所排的順序 |
onCheck | check.bs.table | row, $element | 當(dāng)選擇(check)此行時(shí)觸發(fā),所需的參數(shù)如下: - row:所選擇的行的字段名 - $element:此行的DOM元素 |
onUncheck | uncheck.bs.table | row, $element | 當(dāng)取消選擇(uncheck)此行時(shí)觸發(fā),所需的參數(shù)如下: - row:所取消選擇的行的字段名 - $element:此行的DOM元素 |
onCheckAll | check-all.bs.table | rows | 當(dāng)全選行時(shí)觸發(fā),所需的參數(shù)如下: - rows:最近(newly)所選擇的行的字段名的數(shù)組 |
onUncheckAll | uncheck-all.bs.table | rows | 當(dāng)取消全選行時(shí)觸發(fā),所需的參數(shù)如下: - rows:之前或上次(previously)所選擇的行的字段名的數(shù)組 |
onCheckSome | check-some.bs.table | rows | 當(dāng)選擇(check)某些行(多行,rows)時(shí)觸發(fā),所需的參數(shù)如下: - rows:之前或上次(previously)所選擇的行的字段名的數(shù)組 |
onUncheckSome | uncheck-some.bs.table | rows | 當(dāng)取消選擇(uncheck)某些行(多行,rows)時(shí)觸發(fā),所需的參數(shù)如下: - rows:之前或上次(previously)所選擇的行的字段名的數(shù)組 |
onLoadSuccess | load-success.bs.table | data | 當(dāng)所有數(shù)據(jù)被加載時(shí)觸發(fā) |
onLoadError | load-error.bs.table | status, res | 當(dāng)加載某些數(shù)據(jù)出現(xiàn)錯(cuò)誤時(shí)觸發(fā) |
onColumnSwitch | column-switch.bs.table | field, checked | 當(dāng)某列改變是否可見的狀態(tài)時(shí)觸發(fā) |
onColumnSearch | column-search.bs.table | field, text | 當(dāng)某列被查詢時(shí)觸發(fā) |
onPageChange | page-change.bs.table | number, size | 當(dāng)改變此頁所顯示的數(shù)據(jù)條數(shù)或改變頁碼時(shí)觸發(fā) |
onSearch | search.bs.table | text | 當(dāng)查詢此表時(shí)觸發(fā) |
onToggle | toggle.bs.table | cardView | 當(dāng)改變表的視圖時(shí)觸發(fā) |
onPreBody | pre-body.bs.table | data | 當(dāng) |
onPostBody | post-body.bs.table | data | 當(dāng) |
onPostHeader | post-header.bs.table | none | 當(dāng)中的內(nèi)容被加載完后或者在你所用的DOM中有定義則被觸發(fā) |
onExpandRow | expand-row.bs.table | index, row, $detail | 當(dāng)查看詳細(xì)視圖(點(diǎn)擊查看detail的圖標(biāo))時(shí)觸發(fā) |
onCollapseRow | collapse-row.bs.table | index, row | 當(dāng)關(guān)閉詳細(xì)視圖(再次點(diǎn)擊查看detail的圖標(biāo))時(shí)觸發(fā) |
onRefreshOptions | refresh-options.bs.table | options | 當(dāng)刷新各項(xiàng)后或在初始化表(也包括銷毀了再初始化)之前觸發(fā) |
onResetView | reset-view.bs.table | 當(dāng)重置(reset)表的視圖時(shí)觸發(fā) | |
onRefresh | refresh.bs.table | params | 當(dāng)點(diǎn)擊刷新按鈕(refresh,不是瀏覽器的,而是表格右上角的刷新按鈕)后觸發(fā) |
方法(Methods)
$('#table').bootstrapTable('method', parameter);
方法名 | 參數(shù) | 描述 | 舉例 |
---|---|---|---|
getOptions | none | 返回各項(xiàng)的object | $table.bootstrapTable('getOptions'); - 請查看: getOptions |
getSelections | none | 返回被選擇的行,當(dāng)沒有行被選擇,則返回空數(shù)組(但并不是undefined,也不是null,是長度為0的空數(shù)組,所以可以判斷長度是否大于0來確定是否選擇了行) | $table.bootstrapTable('getSelections'); - 請查看: getSelections |
getAllSelections | none | 返回所有被選的行(原文中:contain search or filter,其實(shí)就是你選擇的篩選之后的數(shù)據(jù)),當(dāng)沒有行被選擇,則返回空數(shù)組 | $table.bootstrapTable('getAllSelections'); - 請查看: getAllSelections |
showAllColumns | none | 顯示所有的列 | $table.bootstrapTable('showAllColumns'); - 就是顯示所有的列,并沒什么可說的 |
hideAllColumns | none | 隱藏所有的列 | $table.bootstrapTable('hideAllColumns'); - 就是隱藏所有的列 |
getData | useCurrentPage | 獲取被加載的表的數(shù)據(jù),如果你設(shè)置了使用當(dāng)前頁的數(shù)據(jù)(useCurrentPage),則返回當(dāng)前頁的數(shù)據(jù) | $table.bootstrapTable('getData'); - 請查看: getData |
getRowByUniqueId | id | 獲取你想要的某行的數(shù)據(jù)(設(shè)置某行的id) | $table.bootstrapTable('getRowByUniqueId', 1);后面的1就是你要的那一行的ID - 請查看: getRowByUniqueId |
load | data | 向表中加載數(shù)據(jù),原來的數(shù)據(jù)將被移除 | $table.bootstrapTable('load', data); - 請查看: load |
append | data | 將數(shù)據(jù)追加在最后一行后 | $table.bootstrapTable('append', data);data可以是數(shù)組 - 請查看: append |
prepend | data | 也是追加,只是在第一行之前 | $table.bootstrapTable('prepend', data);data可以是數(shù)組 - 請查看: prepend |
remove | params | 移除一行或多行你所選的數(shù)據(jù) | $table.bootstrapTable('remove', {field: 'id', values: ids}); - id:所需移除的那一行(rows,一或多行)的字段 - values:被移除的行的數(shù)組 - 請查看: remove |
removeAll | - | 移除表中所有的數(shù)據(jù) | $table.bootstrapTable('removeAll'); - 請查看: removeAll |
removeByUniqueId | - | 移除某行數(shù)據(jù)(設(shè)置某行的id) | $table.bootstrapTable('removeByUniqueId', 1);后面的1就是你想移除的那一行的ID - 請查看: removeByUniqueId |
insertRow | params | 新增一行,所需的參數(shù)如下: - index:你想插入到哪(只要愿意,想插哪就插哪,想插誰就插誰) - row:你想插入的數(shù)據(jù) | $table.bootstrapTable('insertRow', {index: 1, row: row}); - 請查看: insertRow |
updateRow | params | 更新行數(shù)據(jù),所需的參數(shù)如下: - index:所要更新的行的索引(index) - row:你想換的新的數(shù)據(jù) | $table.bootstrapTable('updateRow', {index: 1, row: row}); - 請查看: updateRow |
updateByUniqueId | params | 更新某行數(shù)據(jù),所需的參數(shù)如下: - id:你想更新那行的id(唯一),(只要愿意,想換哪個(gè)換哪個(gè)) - row:你想換的新的數(shù)據(jù) | $table.bootstrapTable('updateByUniqueId', {id: 3, row: row}); - 請查看: updateByUniqueId |
showRow | params | 顯示特定行,所需的參數(shù)至少包括下面所列的一個(gè): - id:所要顯示的行的索引(index) - uniqueId:那一行的id | $table.bootstrapTable('showRow', {index:1}); - 請查看: showRow/hideRow |
hideRow | params | 隱藏特定行,所需的參數(shù)至少包括下面所列的一個(gè): - id:所要隱藏的行的索引(index) - uniqueId:那一行的id | $table.bootstrapTable('hideRow', {index:1}); - 請查看: showRow/hideRow |
getRowsHidden | boolean | 獲取隱藏的行(官方原話很多,其實(shí)總結(jié)起來就前面那一句) | $table.bootstrapTable('getRowsHidden'); |
mergeCells | options | 融合~(把多格合并為一格),所需的參數(shù)如下: - index:所要合并的格所在行的索引(index) - field:所在列的字段名 - rowspan:合并的行總數(shù)目 - colspan:合并的列總數(shù)目 | $table.bootstrapTable('mergeCells', {index: 1, field: 'name', colspan: 2, rowspan: 3}); - 請查看: mergeCells |
updateCell | params | 更新某格數(shù)據(jù),所需的參數(shù)如下: - index:所要合并的格所在行的索引(index) - field:所在列的字段名 - value:要換的新的數(shù)據(jù) 你也可以設(shè)置{reinit:false}來禁用表格的再次初始化 | $table.bootstrapTable('updateCell',{index:index,field:'id',value:value}); |
refresh | params | 刷新服務(wù)端的數(shù)據(jù): - 可以設(shè)置{silent:true}來刷新 - 設(shè)置{url:newUrl,pageNumber:pageNumber, pageSize:pageSize}改變請求的地址,頁數(shù),每頁所顯示的條數(shù) - 可以設(shè)置{query:{foo:'bar'}}增加特定的參數(shù) | $table.bootstrapTable('refresh'); - 請查看: refresh |
refreshOptions | options | 看例子吧 | - 請查看: refreshOptions |
resetSearch | text | 重置搜索的文本(text) | - 請查看: resetSearch |
showLoading | none | 顯示正在加載…… | - 請查看: showLoading/hideLoading |
hideLoading | none | 隱藏正在加載…… | - 請查看: showLoading/hideLoading |
checkAll | none | 選擇當(dāng)前頁的所有行 | $table.bootstrapTable('checkAll'); - 請查看: checkAll/uncheckAll |
uncheckAll | none | 取消選擇當(dāng)前頁的所有行 | $table.bootstrapTable('uncheckAll'); - 請查看: checkAll/uncheckAll |
checkInvert | none | 反向選擇,不難理解吧 | $table.bootstrapTable('checkInvert'); |
check | index | 選擇某一行,索引(index)從0開始 | $table.bootstrapTable('check', 1); - 請查看: check/uncheck |
uncheck | index | 取消選擇某一行,索引(index)從0開始 | $table.bootstrapTable('uncheck', 1); - 請查看: check/uncheck |
checkBy | params | 通過數(shù)組選擇某一行,所需的參數(shù)如下: - field:所要選的字段名 - values:所要選的那些值(數(shù)組) | 官方?jīng)],啊,有例紙: - $("#table").bootstrapTable("checkBy", { field:"field_name", values:["value1","value2","value3"]}); - 請查看: checkBy/uncheckBy |
uncheckBy | params | 通過數(shù)組選擇某一行,所需的參數(shù)如下: - field:所要取消選擇的字段名 - values:所要取消選擇的那些值(數(shù)組) | $("#table").bootstrapTable("uncheckBy", { field:"field_name", values:["value1","value2","value3"]}); - 請查看: checkBy/uncheckBy |
resetView | params | 改變表格的樣式,例如改變表格的高度(height) | $table.bootstrapTable('resetView'); - 請查看: resetView |
resetWidth | none | 自動改變表頭和表腳(就譯成腳,任性)的寬度來適應(yīng)每列的寬度 | $table.bootstrapTable('resetWidth'); |
destroy | none | 銷毀表格 A!T!T!A!C!K! | $table.bootstrapTable('destroy'); - 請查看: destroy |
showColumn | field | 顯示特定的列 | $table.bootstrapTable('showColumn', 'name'); - 請查看: showColumn/hideCoulumn |
hideColumn | field | 隱藏特定的列 | $table.bootstrapTable('hideColumn', 'name'); - 請查看: showColumn/hideCoulumn |
getHiddenColumns | - | 獲取所有隱藏的列 | $table.bootstrapTable('getHiddenColumns'); |
getVisibleColumns | - | 獲取所有顯示的列 | $table.bootstrapTable('getVisibleColumns'); |
scrollTo | value | 滾……到哪個(gè)位置,單位是'px',如果設(shè)為'bottom',嗖,恭喜你已到表尾 | $table.bootstrapTable('scrollTo', 0); - 請查看: scrollTo |
getScrollPosition | none | 獲取當(dāng)前所滾到的位置,單位你懂得,就是'px' | $table.bootstrapTable('getScrollPosition'); |
filterBy | none | 只能在客戶端(client-side,相對server-side)這邊用,過濾表中的數(shù)據(jù) 例如: - 可以設(shè)置{age:10}來只顯示age為10的數(shù)據(jù) - 不僅單的,你還可以雙飛,甚至多p,設(shè)置{age: 10, hairColor: ["blue", "red", "green"]} ,這樣你就得到了一群10歲的,頭發(fā)顏色為藍(lán),紅,綠的……數(shù)據(jù) | $table.bootstrapTable('filterBy', {
id: [1, 2, 3]
}); - 請查看: filterBy |
selectPage | page | 跳轉(zhuǎn)到特定的頁面 | $table.bootstrapTable('selectPage', 1); - 請查看: selectPage/prevPage/nextPage |
prevPage | none | 跳轉(zhuǎn)到上一頁 | $table.bootstrapTable('prevPage'); - 請查看: selectPage/prevPage/nextPage |
nextPage | none | 跳轉(zhuǎn)到下一頁 | $table.bootstrapTable('nextPage'); - 請查看: selectPage/prevPage/nextPage |
togglePagination | none | 詞窮,請看例紙 | $table.bootstrapTable('togglePagination'); - 請查看: togglePagination |
toggleView | none | 改變視圖 | $table.bootstrapTable('toggleView'); - 請查看: toggleView |
expandRow | index | 可使用條件:detail view設(shè)為了true,不然無法使用視圖功能,這個(gè)也沒用 - 通過參數(shù)index來展開此列的詳細(xì)視圖 | - 請查看: expandRow-collapseRow |
collapseRow | index | 可使用條件:detail view設(shè)為了true - 通過參數(shù)index來關(guān)閉此列的詳細(xì)視圖 | - 請查看: expandRow-collapseRow |
expandAllRows 新版有更改(原來為"expandAllRow"),下同 感謝 @zhq449681061 | is subtable | 可使用條件:detail view設(shè)為了true - 展開所有列的詳細(xì)視圖 | $table.bootstrapTable('expandAllRows'); - 參考上面的實(shí)例,上面是展開(折疊)某一行的視圖,這個(gè)是所有行的 |
collapseAllRows | is subtable | 可使用條件:detail view設(shè)為了true - 關(guān)閉所有列的詳細(xì)視圖 | $table.bootstrapTable('collapseAllRows'); - 參考上面 |
本地化,切換為另一種語言(Localizations)
默認(rèn)顯示英文,如果想使用中文,首先引入:
然后是三種聲明使用的方法(個(gè)人只使用第二、三種),如下:
第一種:
$.extend($.fn.bootstrapTable.defaults, $.fn.bootstrapTable.locales['zh-CN']);
第二種:
第三種:
$('table').bootstrapTable({locale:'zh-CN'});
以下說明除了數(shù)字外均為中文默認(rèn)顯示,本來不用寫的,只要引入就顯示中文了
名稱 | 參數(shù) | 默認(rèn) | 說明 |
---|---|---|---|
formatLoadingMessage | - | 'Loading, please wait…' | “加載中,請等待……” |
formatRecordsPerPage | pageNumber | '%s records per page' | “每頁顯示 15 條記錄” |
formatShowingRows | pageFrom, pageTo, totalRows | 'Showing %s to %s of %s rows' | “顯示第 1 到第 15 條記錄” |
formatDetailPagination | totalRows | 'Showing %s rows' | “總共 15 條記錄” |
formatSearch | - | 'Search' | “搜索”(占位符) |
formatNoMatches | - | 'No matching records found' | “沒有找到匹配的記錄” |
formatRefresh | - | 'Refresh' | “刷新”(鼠標(biāo)懸浮顯示的文字,下同) |
formatToggle | - | 'Toggle' | “切換” |
formatColumns | - | 'Columns' | “列” |
上述內(nèi)容就是什么是Bootstrap Table API 中文版,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。