jquery datatables 的常見參數配置
阿新 • • 發佈:2018-01-05
time ucc call 支持 with mob XML cti pan
$(document).ready()是DOM結構繪制完畢後就執行,不必等到加載完畢。
$(document).ready(function() {
oTable = $(‘#example‘).dataTable();
oTable.$(‘tr‘).click( function () {
var data = oTable.fnGetData( this );
// ... do something with the array / object of data for the row
} );
} );
// Individual cell data
$(document).ready(function() {
oTable = $(‘#example‘).dataTable();
oTable.$(‘td‘).click( function () {
var sData = oTable.fnGetData( this );
alert( ‘The cell clicked on had the value of ‘+sData );
} );
} );
$(‘#example‘).dataTable().fnUpdate( [‘a‘,‘b‘] , 1 ); //row
1:導入包:
URL:http://www.datatables.net/
分別導入css和js文件
Html代碼- <</span>style type="text/css" title="currentStyle">
- @import "css/demo_page.css";
- @import "css/demo_table.css";
- @import "css/demo_table_jui.css";
- </</span>style>
- <</span>script type="text/javascript" language="javascript"
- src="js/jquery.js"></</span>script>
- <</span>script type="text/javascript" language="javascript"
- src="js/jquery.dataTables.js"></</span>script>
加載
Html代碼
- <</span>script type="text/javascript">
- $(document).ready(function() {
- $(‘#example‘).dataTable();
- });
- </</span>script>
表單
Html代碼- <</span>div class="col_2_3_right">
- <</span>div class="index_viewport">
- <</span>table id="example" cellpadding="0" cellspacing="0" border="0" width="100%">
- <</span>thead>
- <</span>tr>
- <</span>th width="20%">First name</</span>th>
- <</span>th width="20%">Last name</</span>th>
- <</span>th width="35%">City</</span>th>
- <</span>th width="25%">Date</</span>th>
- </</span>tr>
- </</span>thead>
- </</span>table>
- </</span>div>
- </</span>div>
問題:有時提示找不到datatable方法
原因 window.onload必須等到頁面內包括圖片的所有元素加載完畢後才能執行。$(document).ready()是DOM結構繪制完畢後就執行,不必等到加載完畢。
從後臺ajax得數據重建datatables(表單的id要與json的key一致)
Js代碼- $.ajax({
- type:‘get‘,//可選get
- url:‘${projectPath}/search‘,
- data:{"channelType":$(‘#channelType‘).val(),"channel":$(‘#channel‘).val(),"day":$(‘#day‘).val(),"startTime":$(‘#startTime‘).val(),"endTime":$(‘#endTime‘).val(),"database":$(‘#database‘).val()},
- dataType:‘text‘,//服務器返回的數據類型 可選XML ,Json jsonp script htmltext等
- success:function(msg){
- var msgObj=JSON.parse(msg);
- //重新構建table
- $(‘#example‘).dataTable().fnClearTable(); //將數據清除
- $(‘#example‘).dataTable().fnAddData(packagingdatatabledata(msgObj),true); //數據必須是json對象或json對象數組
- },
- error:function(){
- alert(‘error‘);
- }
- })})
傳入的數據
Js代碼- //把服務器返回的數據轉成datatable須要的格式
- function packagingdatatabledata(msgObj){
- var editHtml="編輯";
- //var editHtml="編輯";
- var a=[];
- var tableName=[‘day‘,‘data‘,‘indata‘,‘edit‘];
- var banddata=storjson(msgObj[‘data‘]);
- var bandindata=storjson(msgObj[‘indata‘]);
- for(var key in banddata){
- var tempObj=new Object();
- tempObj.day=key;
- tempObj.data=banddata[key];
- tempObj.indata=bandindata[key];
- tempObj.edit=editHtml;
- a.push(JSON.parse(JSON.stringify(tempObj,tableName)));
- }
- return a;
- }
傳入的是一個對象數組,每個對象代表一行,對象的屬性即是列
單擊時得到某行的值
須要引入 jquery.dataTables.nightly.js 在附件中有
Js代碼- $(document).ready(function() {
- $(‘#example‘).dataTable();
- $(‘#example tbody tr‘).live(‘click‘, function () {
- var sTitle;
- var nTds = $(‘td‘, this);
- var sday = $(nTds[0]).text(); //得到第1列的值
- var sout = $(nTds[1]).text();
- var sin = $(nTds[2]).text();
- } );
- } );
2:詳細配置
Js代碼- var docrTable = $(‘#docrevisontable‘).dataTable({
- "bProcessing" : true, //DataTables載入數據時,是否顯示‘進度’提示
- "bServerSide" : true, //是否啟動服務器端數據導入
- "bStateSave" : true, //是否打開客戶端狀態記錄功能,此功能在ajax刷新紀錄的時候不會將個性化設定回復為初始化狀態
- "bJQueryUI" : true, //是否使用 jQury的UI theme
- "sScrollY" : 450, //DataTables的高
- "sScrollX" : 820, //DataTables的寬
- "aLengthMenu" : [20, 40, 60], //更改顯示記錄數選項
- "iDisplayLength" : 40, //默認顯示的記錄數
- "bAutoWidth" : false, //是否自適應寬度
- //"bScrollInfinite" : false, //是否啟動初始化滾動條
- "bScrollCollapse" : true, //是否開啟DataTables的高度自適應,當數據條數不夠分頁數據條數的時候,插件高度是否隨數據條數而改變
- "bPaginate" : true, //是否顯示(應用)分頁器
- "bInfo" : true, //是否顯示頁腳信息,DataTables插件左下角顯示記錄數
- "sPaginationType" : "full_numbers", //詳細分頁組,可以支持直接跳轉到某頁
- "bSort" : true, //是否啟動各個字段的排序功能
- "aaSorting" : [[1, "asc"]], //默認的排序方式,第2列,升序排列
- "bFilter" : true, //是否啟動過濾、搜索功能
- "aoColumns" : [{
- "mDataProp" : "USERID",
- "sDefaultContent" : "", //此列默認值為"",以防數據中沒有此值,DataTables加載數據的時候報錯
- "bVisible" : false //此列不顯示
- }, {
- "mDataProp" : "USERNAME",
- "sTitle" : "用戶名",
- "sDefaultContent" : "",
- "sClass" : "center"
- }, {
- "mDataProp" : "EMAIL",
- "sTitle" : "電子郵箱",
- "sDefaultContent" : "",
- "sClass" : "center"
- }, {
- "mDataProp" : "MOBILE",
- "sTitle" : "手機",
- "sDefaultContent" : "",
- "sClass" : "center"
- }, {
- "mDataProp" : "PHONE",
- "sTitle" : "座機",
- "sDefaultContent" : "",
- "sClass" : "center"
- }, {
- "mDataProp" : "NAME",
- "sTitle" : "姓名",
- "sDefaultContent" : "",
- "sClass" : "center"
- }, {
- "mDataProp" : "ISADMIN",
- "sTitle" : "用戶權限",
- "sDefaultContent" : "",
- "sClass" : "center"
- }],
- "oLanguage": { //國際化配置
- "sProcessing" : "正在獲取數據,請稍後...",
- "sLengthMenu" : "顯示 _MENU_ 條",
- "sZeroRecords" : "沒有您要搜索的內容",
- "sInfo" : "從 _START_ 到 _END_ 條記錄 總記錄數為 _TOTAL_ 條",
- "sInfoEmpty" : "記錄數為0",
- "sInfoFiltered" : "(全部記錄數 _MAX_ 條)",
- "sInfoPostFix" : "",
- "sSearch" : "搜索",
- "sUrl" : "",
- "oPaginate": {
- "sFirst" : "第一頁",
- "sPrevious" : "上一頁",
- "sNext" : "下一頁",
- "sLast" : "最後一頁"
- }
- },
- "fnRowCallback" : function(nRow, aData, iDisplayIndex) {
- if (aData.ISADMIN == ‘1‘)
- $(‘td:eq(5)‘, nRow).html(‘管理員‘);
- if (aData.ISADMIN == ‘2‘)
- $(‘td:eq(5)‘, nRow).html(‘資料下載‘);
- if (aData.ISADMIN == ‘3‘)
- $(‘td:eq(5)‘, nRow).html(‘一般用戶‘);
- return nRow;
- },
- "sAjaxSource" : "../use/userList.do?now=" + new Date().getTime(),
- //服務器端,數據回調處理
- "fnServerData" : function(sSource, aDataSet, fnCallback) {
- $.ajax({
- "dataType" : ‘json‘,
- "type" : "POST",
- "url" : sSource,
- "data" : aDataSet,
- "success" : fnCallback
- });
- }
- });
- $("#docrevisontable tbody").click(function(event) { //當點擊表格內某一條記錄的時候,會將此記錄的cId和cName寫入到隱藏域中
- $(docrTable.fnSettings().aoData).each(function() {
- $(this.nTr).removeClass(‘row_selected‘);
- });
- $(event.target.parentNode).addClass(‘row_selected‘);
- var aData = docrTable.fnGetData(event.target.parentNode);
- $("#userId").val(aData.USERID);
- $("#userN").val(aData.USERNAME);
- });
- $(‘#docrevisontable_filter‘).html(‘用戶管理列表‘);
- $(‘#docrevisontable_filter‘).append(‘ ‘);
- $(‘#docrevisontable_filter‘).append(‘ ‘);
- $(‘#docrevisontable_filter‘).append(‘ ‘);
- $(‘#docrevisontable_filter‘).append(‘‘);
- }
設置隱藏列
Js代碼- var oTable = $(‘#example‘).dataTable();
- oTable.fnSetColumnVis( 0, false);//隱藏列
得到當前頁面中的數據
var alldata=$(‘#example‘).dataTable().fnGetData();//得到頁面中所有對象// Row data
$(document).ready(function() {
oTable = $(‘#example‘).dataTable();
oTable.$(‘tr‘).click( function () {
var data = oTable.fnGetData( this );
// ... do something with the array / object of data for the row
} );
} );
// Individual cell data
$(document).ready(function() {
oTable = $(‘#example‘).dataTable();
oTable.$(‘td‘).click( function () {
var sData = oTable.fnGetData( this );
alert( ‘The cell clicked on had the value of ‘+sData );
} );
} );
刷新表中的數據(最後一個參數是否重繪表格,false你瀏覽到第二頁不會刷跑到第一頁,但數據不會改變)
$(‘#example‘).dataTable().fnUpdate( ‘a‘ , 1 , 1 ,false); //coll$(‘#example‘).dataTable().fnUpdate( [‘a‘,‘b‘] , 1 ); //row
得到當前瀏覽的datatables頁碼
Js代碼- var tableSetings=$(‘#example‘).dataTable().fnSettings()
- var paging_length=tableSetings._iDisplayLength;//當前每頁顯示多少
- var page_start=tableSetings._iDisplayStart;//當前頁開始
- var page=Div(page_start,paging_length);
- function Div(exp1, exp2) { //整除
- var n1 = Math.round(exp1); //四舍五入
- var n2 = Math.round(exp2); //四舍五入
- var rslt = n1 / n2; //除
- if (rslt >= 0) {
- rslt = Math.floor(rslt); //返回小於等於原rslt的最大整數。
- }
- else {
- rslt = Math.ceil(rslt); //返回大於等於原rslt的最小整數。
- }
- return rslt;
- }
設置datatables跳轉到某頁
Js代碼- $(‘#example‘).dataTable().fnPageChange(page);
註意:由於後臺數據可能已經被其它人改變(記錄個數與現在前臺不一致),所以數據fnUpdate時須要判斷前後端數據的一致性,只刷 新前臺有的數據的狀態
dom:
http://datatables.net/release-datatables/examples/api/select_single_row.html 選擇一行 http://datatables.net/release-datatables/examples/api/select_row.html選擇多行 http://datatables.net/release-datatables/examples/api/editable.html 即時編輯行 http://datatables.net/release-datatables/examples/api/tabs_and_scrolling.html 多個tab http://datatables.net/release-datatables/examples/api/add_row.html添加一行(靜態) http://datatables.net/release-datatables/examples/api/multi_filter.html多列搜索 http://datatables.net/release-datatables/examples/api/multi_filter_select.html多列搜索(擴展) http://datatables.net/release-datatables/examples/api/highlight.html行列 高亮 http://datatables.net/release-datatables/examples/advanced_init/highlight.html 鼠標移上去亮 http://datatables.net/release-datatables/examples/api/row_details.html行詳細信息 http://datatables.net/release-datatables/examples/api/counter_column.html添加行數 http://datatables.net/release-datatables/examples/api/show_hide.html隱藏列 http://datatables.net/release-datatables/examples/api/api_in_init.html點中即為搜索條件 http://datatables.net/release-datatables/examples/advanced_init/events_live.html 給每一個行添加事件顯示行的信息 http://datatables.net/release-datatables/examples/advanced_init/events_pre_init.html鼠標事件 移到某一行顯示信息 http://datatables.net/release-datatables/examples/advanced_init/events_post_init.html 同上 http://datatables.net/release-datatables/examples/advanced_init/dom_multiple_elements.html 用sdom屬性控制插件位置 http://datatables.net/release-datatables/examples/advanced_init/dom_toolbar.htmlsdom應用 http://datatables.net/release-datatables/examples/advanced_init/length_menu.html更改按多少數據顯示 http://datatables.net/release-datatables/examples/advanced_init/complex_header.html表頭組 http://datatables.net/release-datatables/examples/advanced_init/row_grouping.html按組顯示行 http://datatables.net/release-datatables/examples/advanced_init/row_callback.html列回調函數 http://datatables.net/release-datatables/examples/advanced_init/footer_callback.html總計(footer回調) http://datatables.net/release-datatables/examples/advanced_init/sorting_control.html自定義排序 http://datatables.net/release-datatables/examples/advanced_init/language_file.html國際化 |
jquery datatables 的常見參數配置