欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jQuery表格插件datatables用法詳解

 更新時間:2020年11月23日 15:37:06   作者:SimonMaxs  
這篇文章主要介紹了jQuery表格插件datatables用法,包括分頁、排序等功能,是jQuery表格插件datatables比較基礎(chǔ)的部分知識,需要的朋友可以參考下

一、Datatables簡介

DataTables是一個jQuery的表格插件。這是一個高度靈活的工具,依據(jù)的基礎(chǔ)逐步增強,這將增加先進的互動控制,支持任何HTML表格。主要特點:

  • 自動分頁處理
  • 即時表格數(shù)據(jù)過濾
  • 數(shù)據(jù)排序以及數(shù)據(jù)類型自動檢測
  • 自動處理列寬度
  • 可通過CSS定制樣式
  • 支持隱藏列
  • 易用
  • 可擴展性和靈活性
  • 國際化
  • 動態(tài)創(chuàng)建表格
  • 免費的

二、如何使用

在做后臺的時候并沒有美工和前端工程師來配合你做頁面,為了顯示數(shù)據(jù)并有一定的美感,我們可以使用jQuery的DataTables插件來幫助我們完成任務(wù)

1、DataTables的默認配置

 $(document).ready(function() { 
$('#example').dataTable(); 
} ); 

2、DataTables的一些基礎(chǔ)屬性配置

 "bPaginate": true, //翻頁功能 
"bLengthChange": true, //改變每頁顯示數(shù)據(jù)數(shù)量 
"bFilter": true, //過濾功能 
"bSort": false, //排序功能 
"bInfo": true,//頁腳信息 
"bAutoWidth": true//自動寬度 

3、數(shù)據(jù)排序

$(document).ready(function() { 
$('#example').dataTable( { 
"aaSorting": [ 
[ 4, "desc" ] 
] 
} ); 
} ); 

從第0列開始,以第4列倒序排列
 4、隱藏某些列

$(document).ready(function() { 
$('#example').dataTable( { 
"aoColumnDefs": [ 
{ "bSearchable": false, "bVisible": false, "aTargets": [ 2 ] }, 
{ "bVisible": false, "aTargets": [ 3 ] } 
] } ); 
} ); 

5、國際化

$(document).ready(function() { 
$('#example').dataTable( { 
"oLanguage": { 
"sLengthMenu": "每頁顯示 _MENU_ 條記錄", 
"sZeroRecords": "抱歉, 沒有找到", 
"sInfo": "從 _START_ 到 _END_ /共 _TOTAL_ 條數(shù)據(jù)", 
"sInfoEmpty": "沒有數(shù)據(jù)", 
"sInfoFiltered": "(從 _MAX_ 條數(shù)據(jù)中檢索)", 
"oPaginate": { 
"sFirst": "首頁", 
"sPrevious": "前一頁", 
"sNext": "后一頁", 
"sLast": "尾頁" 
}, 
"sZeroRecords": "沒有檢索到數(shù)據(jù)", 
"sProcessing": "<img src='./loading.gif' />" 
} 
} ); 
} ); 

6、排序功能:

$(document).ready(function() { 
$('#example').dataTable( { 
"aoColumns": [ 
null, 
{ "asSorting": [ "asc" ] }, 
{ "asSorting": [ "desc", "asc", "asc" ] }, 
{ "asSorting": [ ] }, 
{ "asSorting": [ ] } 
] 
} ); 
} ); 

7、數(shù)據(jù)獲取支持4種:如下

  • •DOM   文檔數(shù)據(jù) 
  • •Javascript array  js數(shù)組 
  • •Ajax source     Ajax請求數(shù)據(jù) 
  • •Server side processing  服務(wù)器端數(shù)據(jù) 

三、實例講解

1、需求:如下圖所示,對datatables的內(nèi)容進行添加,編輯,刪除的操作。

2、分析:添加功能---單擊add按鈕,彈出對話框,添加新的內(nèi)容。

編輯功能---單擊datatables可以選中一行,此行改變顏色,即是已經(jīng)選中,單擊edit按鈕,彈出dialog,此dialog中的內(nèi)容是我們選中行的內(nèi)容。如果沒有選中行,點擊edit按鈕,則不會彈出dialog。當雙擊datatables中的某一行時,也彈出dialog,并且雙擊的行改變顏色,dialog中的內(nèi)容是我們雙擊行的內(nèi)容。

刪除功能---單擊datatables選中一行,單擊delete按鈕,彈出警告框,提示要不要刪除所選內(nèi)容。當沒有選中任何內(nèi)容時,單擊delete按鈕,不會彈出警告框,也不會刪除內(nèi)容。

3、編碼:

Attributes//名稱

 <table id="gridtable" class="gridtable">//聲明jquery datatables 
 <thead> 
  <tr> 
  <th>Name 
  </th> 
  <th>Value 
  </th> 
  <th>DisplayOrder 
  </th> 
 </tr> 
 </thead> 
 <tbody> 
 .....//datatables內(nèi)容,此處省略 
 </tbody> 
</table> 
<input type="button" id="add" value="Add" />//添加按鈕 
<input type="button" id="edit" value="Edit" />//編輯按鈕 
<input type="button" id="delete" value="Delete" />//刪除按鈕 
 
 
<div id="e_Attributes">//聲明dialog,異步更新 
 @using (Ajax.BeginForm("Update", "Product", new AjaxOptions 
{ 
 UpdateTargetId = "d_Attributes", 
 OnSuccess = "dialogClose", 
 HttpMethod = "Post", 
})) 
 { 
 <table> 
  <tbody> 
  <tr>    
   <td>Name</td> 
   <td> 
   <input id="name" name="Name" type="text" style="width:250px" class="required"/>*</td> 
  </tr> 
  <tr> 
   <td>Value</td> 
   <td> 
   <input id="value" name="Value" type="text" style="width:250px" class="required"/>*</td> 
  </tr> 
  <tr> 
   <td>DisplayOrder</td> 
   <td> 
   <input id="displayOrder" name="DisplayOrder" type="text" style="width:128px" class="required"/>*</td> 
  </tr> 
  <tr> 
   <td> 
   <input id="submit" type="submit" name="submit" value="Submit" /> 
   <input id="hiddenValue" type="hidden" name="hiddenValue" /> 
   </td> 
  </tr> 
  </tbody> 
 </table> 
 } 
</div> 

上面代碼說明:這段代碼主要分了兩個部分,第一部分是jquery datatables的聲明,<table id="gridtable" class="gridtable">;第二部分是dialog的聲明,以及操作所需要的action,此部分的操作選擇ajax無刷新頁面技術(shù)。所需js的代碼:

<script type="text/javascript"> 
 function dialogClose() { 
  $("#e_Attributes").dialog("close"); 
 } 
 
 $("#e_Attributes").dialog({ 
  modal: true, 
  autoOpen: false, 
  show: { 
  effect: "blind", 
  duration: 1000 
  }, 
  hide: { 
  effect: "explode", 
  duration: 1000 
 }, 
 width: 400 
 }); 
 
 var editor; 
 
 $(function () { 
 //聲明datatable 
  $("#gridtable").dataTable().fnDestroy(); 
  editor = $('#gridtable').dataTable({ 
  "bInfo":false, 
  "bServerSide": false, 
  'bPaginate': false,   //是否分頁。 
  "bProcessing": false,   //當datatable獲取數(shù)據(jù)時候是否顯示正在處理提示信息。 
  'bFilter': false,   //是否使用內(nèi)置的過濾功能。 
  'bLengthChange': false,   //是否允許用戶自定義每頁顯示條數(shù)。 
  'sPaginationType': 'full_numbers', //分頁樣式 
  }); 
 //單擊,賦值,改樣式 
 $("#gridtable tbody tr").click(function (e) { 
  if ($(this).hasClass('row_selected')) { 
  $(this).removeClass('row_selected'); 
  putNullValue() 
  } 
  else { 
  editor.$('tr.row_selected').removeClass('row_selected'); 
  $(this).addClass('row_selected'); 
  var aData = editor.fnGetData(this); 
  if (null != aData) { 
   putValue(aData); 
  } 
  } 
 }); 
 //雙擊 
 $("#gridtable tbody tr").dblclick(function () { 
  if ($(this).hasClass('row_selected')) { 
  //$(this).removeClass('row_selected'); 
  } 
  else { 
  editor.$('tr.row_selected').removeClass('row_selected'); 
  $(this).addClass('row_selected'); 
  } 
 
  var aData = editor.fnGetData(this); 
  if (null != aData) { 
  putValue(aData); 
  } 
 
  $("#hiddenValue").val("edit"); 
  $("#e_Attributes").dialog("open"); 
 
 }); 
 //添加 
 $("#add").click(function () { 
  editor.$('tr.row_selected').removeClass('row_selected'); 
  putNullValue(); 
 
  $("#hiddenValue").val("add"); 
  $("#e_Attributes").dialog("open"); 
 }); 
 //編輯 
 $("#edit").click(function () { 
  var productAttributeID = $("#productAttributeID").val(); 
  if (productAttributeID != "" && productAttributeID != null) { 
  $("#hiddenValue").val("edit"); 
  $("#e_Attributes").dialog("open"); 
  } 
 
 }); 
 //刪除 
 $("#delete").click(function () { 
  var productAttributeID = $("#productAttributeID").val(); 
  var productID = $("#productID").val(); 
  if (productAttributeID != null && productAttributeID != "") { 
  if (confirm("Delete?")) { 
   $.ajax({ 
   type: "GET", 
   url: "@Url.Action("DeleteAttribute", "Product")", 
   data: { ProductID: productID, ProductAttributeID: productAttributeID },//參數(shù)名要和Action 中的參數(shù)名相同 
   dataType: "html", 
   cache: false, 
   success: function (result) { 
    $("#d_Attributes").html(result); 
    $("#productAttributeID").val(null); 
   } 
   }); 
  } 
  } 
 }); 
 
 //賦空值,并去除input-validation-error樣式(此樣式不管有無,均可去除,所以不用判斷了) 
 function putNullValue() { 
  。。。。。。//此處省略 
 } 
 //賦值 
 function putValue(aData) { 
  。。。。。。//此處省略 
 } 
 }); 
 
 $.ajaxSetup({ cache: false }); 
</script>

上面代碼說明:這段代碼分別為dialog 的聲明,datatables的聲明以add,edit,delete的操作。
添加功能效果圖

編輯功能效果圖:

刪除效果圖:

到此,功能已經(jīng)全部實現(xiàn),所需的代碼也已經(jīng)貼出。
4、分頁實現(xiàn)

引入CSS文件和JS文件

<style type="text/css" title="currentStyle"> 
 @import "DataTables-1.8.1/media/css/demo_page.css"; 
 @import "DataTables-1.8.1/media/css/demo_table.css"; 
 @import "DataTables-1.8.1/media/css/demo_table_jui.css"; 
</style> 
<script type="text/javascript" language="javascript" src="DataTables-1.8.1/media/js/jquery.js"></script> 
<script type="text/javascript" language="javascript" src="DataTables-1.8.1/media/js/jquery.dataTables.js"></script> 
 
 -------------------------------------------------------------------------- 
 
-----------最簡單的方式: 
 $(document).ready(function() { 
 $("#example").dataTable(); 
}); 
 
----------也可以自己定義各屬性: 
<script type="text/javascript" language="javascript"> 
 $(document).ready(function() { 
  $("#example").dataTable({ 
//  "bPaginate": true, //開關(guān),是否顯示分頁器 
//  "bInfo": true, //開關(guān),是否顯示表格的一些信息 
//  "bFilter": true, //開關(guān),是否啟用客戶端過濾器 
//  "sDom": "<>lfrtip<>", 
//  "bAutoWith": false, 
//  "bDeferRender": false, 
//  "bJQueryUI": false, //開關(guān),是否啟用JQueryUI風格 
//  "bLengthChange": true, //開關(guān),是否顯示每頁大小的下拉框 
//  "bProcessing": true, 
//  "bScrollInfinite": false, 
//  "sScrollY": "800px", //是否開啟垂直滾動,以及指定滾動區(qū)域大小,可設(shè)值:'disabled','2000px' 
//  "bSort": true, //開關(guān),是否啟用各列具有按列排序的功能 
//  "bSortClasses": true, 
//  "bStateSave": false, //開關(guān),是否打開客戶端狀態(tài)記錄功能。這個數(shù)據(jù)是記錄在cookies中的,打開了這個記錄后,即使刷新一次頁面,或重新打開瀏覽器,之前的狀態(tài)都是保存下來的- ------當值為true時aoColumnDefs不能隱藏列 
//  "sScrollX": "50%", //是否開啟水平滾動,以及指定滾動區(qū)域大小,可設(shè)值:'disabled','2000%' 
//  "aaSorting": [[0, "asc"]], 
//  "aoColumnDefs": [{ "bVisible": false, "aTargets": [0]}]//隱藏列 
//  "sDom": '<"H"if>t<"F"if>', 
  "bAutoWidth": false, //自適應(yīng)寬度 
  "aaSorting": [[1, "asc"]], 
  "sPaginationType": "full_numbers", 
  "oLanguage": { 
   "sProcessing": "正在加載中......", 
   "sLengthMenu": "每頁顯示 _MENU_ 條記錄", 
   "sZeroRecords": "對不起,查詢不到相關(guān)數(shù)據(jù)!", 
   "sEmptyTable": "表中無數(shù)據(jù)存在!", 
   "sInfo": "當前顯示 _START_ 到 _END_ 條,共 _TOTAL_ 條記錄", 
   "sInfoFiltered": "數(shù)據(jù)表中共為 _MAX_ 條記錄", 
   "sSearch": "搜索", 
   "oPaginate": { 
   "sFirst": "首頁", 
   "sPrevious": "上一頁", 
   "sNext": "下一頁", 
   "sLast": "末頁" 
   } 
  } //多語言配置 
 
  }); 
 }); 
 </script> 

對于 dataTables 來說,表格必須通過 thead 和 tbody 進行說明,如下所示

<table cellpadding="0" cellspacing="0" border="0" class="display" id="example"> 
 <thead> 
  <tr> 
  <th> 
   Rendering engine 
  </th> 
  <th> 
   Browser 
  </th> 
  <th> 
   Platform(s) 
  </th> 
  <th> 
   Engine version 
  </th> 
  <th> 
   CSS grade 
  </th> 
  </tr> 
 </thead> 
 <tbody> 
  <tr class="odd gradeX"> 
  <td> 
   Trident 
  </td> 
  <td> 
   Internet Explorer 4.0 
  </td> 
  <td> 
   Win 95+ 
  </td> 
  <td class="center"> 
   4 
  </td> 
  <td class="center"> 
   X 
  </td> 
  </tr>

如果沒有 thead 將會報錯。

  • bPaginate: 是否分頁,默認為 true,分頁
  • iDisplayLength : 每頁的行數(shù),每頁默認數(shù)量:10
  • sPaginationType: 分頁樣式,支持兩種內(nèi)置方式,two_button 和 full_numbers, 默認使用 two_button。
  • bLengthChange : 是否允許用戶通過一個下拉列表來選擇分頁后每頁的行數(shù)。行數(shù)為 10,25,50,100。這個設(shè)置需要 bPaginate 支持。默認為 true。
  • bFilter: 啟用或禁止數(shù)據(jù)過濾,默認為 true。 注意,如果使用過濾功能,但是希望關(guān)閉默認的過濾輸入框,應(yīng)使用 sDom
  • bInfo: 允許或者禁止表信息的顯示,默認為 true,顯示信息。

最為簡單的使用方式,就是零配置的方式。

/*
 * Example init
 */
$(document).ready(function(){
 $('#example').dataTable();
});

以上就是關(guān)于jQuery表格插件datatables用法的詳細介紹,希望對大家的學習有所幫助。

相關(guān)文章

  • jQuery實現(xiàn)簡易計算器功能

    jQuery實現(xiàn)簡易計算器功能

    這篇文章主要為大家詳細介紹了jQuery實現(xiàn)簡易計算器功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 解決jquery submit()提交表單提示:f[s] is not a function

    解決jquery submit()提交表單提示:f[s] is not a function

    jquery submit()無法提交表單 報錯:f[s] is not a function,很是疑惑搜集整理了一些解決方法,感興趣的朋友可以了解下啊,希望本文對你有所幫助
    2013-01-01
  • jQuery實現(xiàn)淡入淡出的模態(tài)框

    jQuery實現(xiàn)淡入淡出的模態(tài)框

    這篇文章主要為大家詳細介紹了jQuery實現(xiàn)淡入淡出的模態(tài)框,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • jQuery生成假加載動畫效果

    jQuery生成假加載動畫效果

    在使用PDFObject.js時,由于后臺需要轉(zhuǎn)換數(shù)據(jù),在前臺顯示的時候,有很長一段時間顯示空白頁面,所以想到寫一個假的加載動畫,下面看下實現(xiàn)代碼
    2016-12-12
  • jquery捕捉回車鍵及獲取checkbox值與異步請求的方法

    jquery捕捉回車鍵及獲取checkbox值與異步請求的方法

    這篇文章主要介紹了jquery捕捉回車鍵及獲取checkbox值與異步請求的方法,實例分析了jQuery針對回車鍵的捕捉,checkbox值的獲取以及異步請求的響應(yīng)等相關(guān)技巧,需要的朋友可以參考下
    2015-12-12
  • 基于jQuery實現(xiàn)表格內(nèi)容的篩選功能

    基于jQuery實現(xiàn)表格內(nèi)容的篩選功能

    這篇文章主要介紹了基于jQuery實現(xiàn)表格內(nèi)容的篩選功能的相關(guān)資料,需要的朋友可以參考下
    2016-08-08
  • jquery入門——事件機制之事件中的冒泡現(xiàn)象示例解釋

    jquery入門——事件機制之事件中的冒泡現(xiàn)象示例解釋

    事件被觸發(fā)后被分為兩個階段,一個是捕獲(Capture),另一個是冒泡(Bubbing),但大多瀏覽器并不是都支持捕獲階段,因此事件被觸發(fā)后,往往執(zhí)行冒泡過程,感興趣的朋友可以了解下,或許對你學習事件機制有所幫助
    2013-02-02
  • jQuery實現(xiàn)內(nèi)容定時切換效果完整實例

    jQuery實現(xiàn)內(nèi)容定時切換效果完整實例

    這篇文章主要介紹了jQuery實現(xiàn)內(nèi)容定時切換效果,以完整實例形式較為詳細的分析了jQuery結(jié)合時間函數(shù)針對內(nèi)容的定時切換顯示相關(guān)技巧,需要的朋友可以參考下
    2016-04-04
  • Jquery Easyui進度條組件Progress使用詳解(8)

    Jquery Easyui進度條組件Progress使用詳解(8)

    這篇文章主要為大家詳細介紹了Jquery Easyui進度條組件Progress的使用方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • jquery實現(xiàn)簡單下拉菜單效果

    jquery實現(xiàn)簡單下拉菜單效果

    這篇文章主要為大家詳細介紹了jquery實現(xiàn)簡單下拉菜單效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04

最新評論