最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

jQuerydatatables表格插件介绍

来源:动视网 责编:小采 时间:2020-11-27 20:32:14
文档

jQuerydatatables表格插件介绍

jQuerydatatables表格插件介绍:一、Datatables简介 DataTables是一个jQuery的表格插件。这是一个高度灵活的工具,依据的基础逐步增强,这将增加先进的互动控制,支持任何HTML表格。主要特点: 自动分页处理 即时表格数据过滤 数据排序以及数据类型自动检测 自动处理列宽度 可通过CSS
推荐度:
导读jQuerydatatables表格插件介绍:一、Datatables简介 DataTables是一个jQuery的表格插件。这是一个高度灵活的工具,依据的基础逐步增强,这将增加先进的互动控制,支持任何HTML表格。主要特点: 自动分页处理 即时表格数据过滤 数据排序以及数据类型自动检测 自动处理列宽度 可通过CSS
 一、Datatables简介

DataTables是一个jQuery的表格插件。这是一个高度灵活的工具,依据的基础逐步增强,这将增加先进的互动控制,支持任何HTML表格。主要特点:

  1. 自动分页处理
  2. 即时表格数据过滤
  3. 数据排序以及数据类型自动检测
  4. 自动处理列宽度
  5. 可通过CSS定制样式
  6. 支持隐藏列
  7. 易用
  8. 可扩展性和灵活性
  9. 国际化
  10. 动态创建表格
  11. 免费的

二、如何使用

在做后台的时候并没有美工和前端工程师来配合你做页面,为了显示数据并有一定的美感,我们可以使用jQuery的DataTables插件来帮助我们完成任务。

1、DataTables的默认配置

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

2、DataTables的一些基础属性配置

"bPaginate": true, //翻页功能 
"bLengthChange": true, //改变每页显示数据数量 
"bFilter": true, //过滤功能 
"bSort": false, //排序功能 
"bInfo": true,//页脚信息 
"bAutoWidth": true//自动宽度 

3、数据排序

$(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_ 条数据",
 "sInfoEmpty": "没有数据",
 "sInfoFiltered": "(从 _MAX_ 条数据中检索)",
 "oPaginate": {
 "sFirst": "首页",
 "sPrevious": "前一页",
 "sNext": "后一页",
 "sLast": "尾页"
 },
 "sZeroRecords": "没有检索到数据",
 "sProcessing": ""
 }
 });
});

6、排序功能:

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

7、数据获取支持4种:如下

  1. DOM 文档数据
  2. Javascript array js数组
  3. Ajax source Ajax请求数据
  4. Server side processing 服务器端数据

三、实例讲解

1、需求:如下图所示,对datatables的内容进行添加,编辑,删除的操作。

2、分析:

  1. 添加功能---单击add按钮,弹出对话框,添加新的内容。
  2. 编辑功能---单击datatables可以选中一行,此行改变颜色,即是已经选中,单击edit按钮,弹出dialog,此dialog中的内容是我们选中行的内容。如果没有选中行,点击edit按钮,则不会弹出dialog。当双击datatables中的某一行时,也弹出dialog,并且双击的行改变颜色,dialog中的内容是我们双击行的内容。
  3. 删除功能---单击datatables选中一行,单击delete按钮,弹出警告框,提示要不要删除所选内容。当没有选中任何内容时,单击delete按钮,不会弹出警告框,也不会删除内容。

3、 编码:

//声明jquery datatables 
  
 .....//datatables内容,此处省略 
 
Name Value DisplayOrder
//添加按钮 //编辑按钮 //删除按钮 //声明dialog,异步更新 @using (Ajax.BeginForm("Update", "Product", new AjaxOptions { UpdateTargetId = "d_Attributes", OnSuccess = "dialogClose", HttpMethod = "Post", })) {
Name *
Value *
DisplayOrder *
}

代码说明,这段代码主要分了两个部分。

第一部分是jquery datatables的声明,

第二部分是dialog的声明,以及操作所需要的action,此部分的操作选择ajax无刷新页面技术。所需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获取数据时候是否显示正在处理提示信息。 
 'bFilter': false,
 //是否使用内置的过滤功能。 
 'bLengthChange': false,
 //是否允许用户自定义每页显示条数。 
 '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
 },
 //参数名要和Action 中的参数名相同 
 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
}); 

这段代码分别为dialog 的声明,datatables的声明以add,edit,delete的操作。

添加功能效果图

编辑功能效果图:

删除效果图:

到此,功能已经全部实现,所需的代码也已经贴出。

4、分页实现

引入CSS文件和JS文件

 
 
 
 
 -------------------------------------------------------------------------- 
 
-----------最简单的方式: 
 $(document).ready(function() { 
 $("#example").dataTable(); 
}); 
 
----------也可以自己定义各属性: 

对于 dataTables 来说,表格必须通过 thead 和 tbody 进行说明,如下所示,

如果没有 thead 将会报错。

  1. bPaginate: 是否分页,默认为 true,分页
  2. iDisplayLength : 每页的行数,每页默认数量:10
  3. sPaginationType: 分页样式,支持两种内置方式,two_button 和 full_numbers, 默认使用 two_button。
  4. bLengthChange : 是否允许用户通过一个下拉列表来选择分页后每页的行数。行数为 10,25,50,100。这个设置需要 bPaginate 支持。默认为 true。
  5. bFilter: 启用或禁止数据过滤,默认为 true。 注意,如果使用过滤功能,但是希望关闭默认的过滤输入框,应使用 sDom
  6. bInfo: 允许或者禁止表信息的显示,默认为 true,显示信息。

最为简单的使用方式,就是零配置的方式。

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

文档

jQuerydatatables表格插件介绍

jQuerydatatables表格插件介绍:一、Datatables简介 DataTables是一个jQuery的表格插件。这是一个高度灵活的工具,依据的基础逐步增强,这将增加先进的互动控制,支持任何HTML表格。主要特点: 自动分页处理 即时表格数据过滤 数据排序以及数据类型自动检测 自动处理列宽度 可通过CSS
推荐度:
标签: 介绍 简介 jQuery
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top
Rendering engine Browser Platform(s) Engine version CSS grade
Trident Internet Explorer 4.0 Win 95+ 4 X