jQuery表格插件datatables用法匯總
DataTables是一個(gè)jQuery的表格插件,本文為大家分享了表格插件datatables用法,介紹了基礎(chǔ)的部分知識,具體內(nèi)容如下
一、初始化
在頁面中
<!DOCTYPE html> <html> <head> <link rel="stylesheet" type="text/css" > <script type="text/javascript" charset="utf8" src="http://cdn.datatables.net/1.10.11/js/jquery.dataTables.js"></script> </head> <body> <table id="table_id" class="display"> <thead> <tr> <th>Column 1</th> <th>Column 2</th> </tr> </thead> <tbody> <tr> <td>Row 1 Data 1</td> <td>Row 1 Data 2</td> </tr> <tr> <td>Row 2 Data 1</td> <td>Row 2 Data 2</td> </tr> </tbody> </table> </body> </html>
js中初始化
$(document).ready( function () {
$('#table_id').DataTable();
} );
二、常用配置
在初始化的時(shí)候可以通過一些常用的配置項(xiàng)對表格進(jìn)行配置,這是我在項(xiàng)目中實(shí)際用到的
$("#vivo_table_list").dataTable({
pageLength: 10, //更改初始頁面長度 (每頁的行數(shù))
processing: true, //顯示正在處理字符串
serverSide: false, // 服務(wù)器模式,這一點(diǎn)非常奇怪*
ordering: true, // 是否啟用Datatables排序
searching: false, // 開啟搜索
autoWidth: false,
zeroRecords: "沒有查詢數(shù)據(jù)",
destroy: true, // 從當(dāng)前上下文銷毀掉Datatables對象 (妹搞懂)
pagingType: "input", // 分頁按鈕種類顯示選項(xiàng)
language: {
url: "cn.txt" // 本地化
},
dom: "tr<'row-fluid'<'span6'i><'span6'p>>", // 按什么順序定義表的控制元素在頁面上出現(xiàn)(妹搞懂)
ajax: {
url: "/url",
type: "post", // ajax請求的類型 **
data: function () {
return that.getQueryParams(); // ajax的參數(shù)
}
},
columns: [
{title: "id", data: "id", orderable: true},
{title: "uid", data: "uid", orderable: false},
{title: "昵稱", data: "nick", orderable: false},
{title: "姓名", data: "name", orderable: false},
{title: "電話", data: "tel", orderable: false},
{title: "申請時(shí)間", data: "stimeshow", orderable: true},
{title: "狀態(tài)", data: "statshow", orderable: false},
{
title: "操作", orderable: false, render: function (data,type,full) {
return '<button id="msgsndButton" class="msgsnd glyphicon glyphicon-comment"></button>' +
' <button id="forbidButton" class="forbid glyphicon glyphicon-thumbs-down"></button>'+
'<input type="hidden" value="'+full.id+'"/>';
}
}
]
});
后臺傳回的數(shù)據(jù)一定要是一個(gè)map,key是 "data",value 是數(shù)據(jù)(如果數(shù)據(jù)是List要 toArray()),其中 data 也是 DataTables 的參數(shù)之一,表示表格要顯示的數(shù)據(jù),所以你可以在這個(gè)map中放上其他的表格參數(shù),只要把key設(shè)置為參數(shù)名就可以了。
*:配置中serverSide開啟服務(wù)器模式,在工作使用中表格的數(shù)據(jù)是通過ajax從后臺獲取,就理所當(dāng)然地打開了這個(gè)模式,但是表格對某一列排序的功能就失效了,而隨后我關(guān)閉了這一模式,發(fā)現(xiàn)就可以對表格中的列進(jìn)行排序,表格的數(shù)據(jù)還是從服務(wù)器獲取……所以這個(gè)模式還有待研究
**: 在項(xiàng)目中后臺controller接收的參數(shù)是數(shù)組,ajax的請求包含復(fù)雜參數(shù)的時(shí)候,請求的類型一定要是post;
三、進(jìn)階功能
1、隱藏列
可以通過 "columns.visible" 屬性規(guī)定列是否顯示,但是這樣就不能獲取此列的值,如果要隱藏id列,又要根據(jù)id觸發(fā)事件就辦不到了 = =,后來查API后想了一個(gè)笨辦法,可以借助 columns.render 屬性,用法如下:
{
title: "操作", orderable: false, render: function (data,type,full) {
return '<input type="hidden" value="'+full.id+'"/>';
}
}
注意 render 后的函數(shù)有三個(gè)參數(shù),data/type/full,其中full參數(shù)是行的所有數(shù)據(jù)(官網(wǎng)在此注明:只是行中的數(shù)據(jù),而不是data屬性的值,所以就算data中有你想要的值,但你沒有給他一列的話也是獲取不到的),可以在render中直接使用你想隱藏的值,如果表格外部要引用這個(gè)值,可以在render中組裝一個(gè)隱藏的<input>,外部就可以獲取到了,不過這種方法真的非常蠢,如果你有好的方法,請一定要告訴我。
2、輸入頁碼跳轉(zhuǎn)頁面
我們可以通過 pagingType 屬性來設(shè)置表格分頁按鈕樣式,但是DataTables的幾個(gè)默認(rèn)樣式都沒有項(xiàng)目中需要的輸入頁碼進(jìn)行跳轉(zhuǎn)的樣式。但是在官網(wǎng)的 plug-in 頁中介紹了幾種分頁按鈕的插件,其中的 input 分頁插件就可以滿足我們的需求,只要引入插件的js,再將 pagingType 的值改為 "input" 就可以了。js文件的 CDN 是:
//cdn.datatables.net/plug-ins/1.10.11/pagination/input.js
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助。
- jQuery Datatables 動態(tài)列+跨列合并實(shí)現(xiàn)代碼
- jQuery+Datatables實(shí)現(xiàn)表格批量刪除功能【推薦】
- jQuery+datatables插件實(shí)現(xiàn)ajax加載數(shù)據(jù)與增刪改查功能示例
- jQuery Datatables表頭不對齊的解決辦法
- jQuery插件DataTables分頁開發(fā)心得體會
- JQuery.dataTables表格插件添加跳轉(zhuǎn)到指定頁
- jQuery中Datatables增加跳轉(zhuǎn)到指定頁功能
- 利用JQuery實(shí)現(xiàn)datatables插件的增加和刪除行功能
- jQuery.datatables.js插件用法及api實(shí)例詳解
- jQuery dataTables與jQuery UI 對話框dialog的使用教程
- jquery表格datatables實(shí)例解析 直接加載和延遲加載
- jQuery插件dataTables添加序號列的方法
- jQuery DataTables插件自定義Ajax分頁實(shí)例解析
- jQuery插件datatables使用教程
- jQuery表格插件datatables用法詳解
- jquery+php實(shí)現(xiàn)導(dǎo)出datatables插件數(shù)據(jù)到excel的方法
- jQuery表格插件datatables用法總結(jié)
- Jquery Datatables的使用詳解
相關(guān)文章
jquery創(chuàng)建一個(gè)新的節(jié)點(diǎn)對象(自定義結(jié)構(gòu)/內(nèi)容)的好方法
jq創(chuàng)建一個(gè)新的節(jié)點(diǎn)對象,這對一些自定義功能很有幫助,而且可以隨意控制對象的結(jié)構(gòu)與內(nèi)容,何樂而不為呢,看到這里,相信有些朋友已經(jīng)按耐不住了,好記下來為大家介紹實(shí)現(xiàn)方法,感興趣的朋友可以了解下哦2013-01-01
jQuery學(xué)習(xí)筆記之DOM對象和jQuery對象
DOM對象和jQuery對象的操作時(shí)很重要的,是jquery與頁面元素互動的基礎(chǔ)。2010-12-12
jQuery Validate設(shè)置onkeyup驗(yàn)證的實(shí)例代碼
jQuery Validate 插件為表單提供了強(qiáng)大的驗(yàn)證功能,讓客戶端表單驗(yàn)證變得更簡單,同時(shí)提供了大量的定制選項(xiàng),滿足應(yīng)用程序各種需求。這篇文章主要介紹了jQuery Validate設(shè)置onkeyup驗(yàn)證的相關(guān)資料,需要的朋友可以參考下2016-12-12
CSS3 media queries結(jié)合jQuery實(shí)現(xiàn)響應(yīng)式導(dǎo)航
這篇文章主要為大家詳細(xì)介紹了CSS3 media queries結(jié)合jQuery實(shí)現(xiàn)響應(yīng)式導(dǎo)航,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09
JQuery實(shí)現(xiàn)當(dāng)鼠標(biāo)停留在某區(qū)域3秒后自動執(zhí)行
這篇文章主要介紹了JQuery實(shí)現(xiàn)當(dāng)鼠標(biāo)停留在某區(qū)域3秒后自動執(zhí)行,可以應(yīng)用于很多場景,需要的朋友可以參考下2014-09-09
Jquery Ajax學(xué)習(xí)實(shí)例6 向WebService發(fā)出請求,返回DataSet(XML) 異步調(diào)用
Jquery Ajax學(xué)習(xí)實(shí)例6 向WebService發(fā)出請求,返回DataSet(XML) 異步調(diào)用實(shí)現(xiàn)代碼,需要的朋友可以參考下。2010-03-03
jQuery實(shí)現(xiàn)智能判斷固定導(dǎo)航條或側(cè)邊欄的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)智能判斷固定導(dǎo)航條或側(cè)邊欄的方法,涉及jQuery針對頁面元素屬性的判斷與動態(tài)操作相關(guān)技巧,需要的朋友可以參考下2016-09-09
ASP.NET jQuery 實(shí)例14 在ASP.NET form中校驗(yàn)時(shí)間范圍
這節(jié)主要講如何用jQuery校驗(yàn)表單時(shí)間范圍,時(shí)間控件用到了jQuery-ui2012-02-02

