初始化

在页面中

<!DOCTYPE html>
<html><head><link rel="stylesheet" type="text/css" href="//cdn.datatables.net/1.10.11/css/jquery.dataTables.css"><script type="text/javascript" charset="utf8" src="//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();
} );

常用配置

在初始化的时候可以通过一些常用的配置项对表格进行配置,这是我在项目中实际用到的

$("#vivo_table_list").dataTable({pageLength: 10,     //更改初始页面长度 (每页的行数)processing: true,    //显示正在处理字符串serverSide: false,    // 服务器模式,这一点非常奇怪*ordering: true,          // 是否启用Datatables排序searching: false,      // 开启搜索autoWidth: false,zeroRecords: "没有查询数据",destroy: true,            // 从当前上下文销毁掉Datatables对象 (妹搞懂)pagingType: "input",    // 分页按钮种类显示选项language: {url: "cn.txt"    // 本地化},dom: "tr<'row-fluid'<'span6'i><'span6'p>>",    // 按什么顺序定义表的控制元素在页面上出现(妹搞懂)ajax: {url: "/url",type: "post",    // ajax请求的类型 **data: function () {return that.getQueryParams();    // ajax的参数}},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: "申请时间", data: "stimeshow", orderable: true},{title: "状态", 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+'"/>';}}]});

后台传回的数据一定要是一个map,key是 "data",value 是数据(如果数据是List要 toArray()),其中 data 也是 DataTables 的参数之一,表示表格要显示的数据,所以你可以在这个map中放上其他的表格参数,只要把key设置为参数名就可以了。

*:配置中serverSide开启服务器模式,在工作使用中表格的数据是通过ajax从后台获取,就理所当然地打开了这个模式,但是表格对某一列排序的功能就失效了,而随后我关闭了这一模式,发现就可以对表格中的列进行排序,表格的数据还是从服务器获取……所以这个模式还有待研究

** : 在项目中后台controller接收的参数是数组,ajax的请求包含复杂参数的时候,请求的类型一定要是post;

进阶功能

隐藏列

可以通过 "columns.visible" 属性规定列是否显示,但是这样就不能获取此列的值,如果要隐藏id列,又要根据id触发事件就办不到了 = =,后来查API后想了一个笨办法,可以借助 columns.render 属性,用法如下:

{title: "操作", orderable: false, render: function (data,type,full) {return '<input type="hidden" value="'+full.id+'"/>';}
}

注意 render 后的函数有三个参数,data/type/full,其中full参数是行的所有数据(官网在此注明:只是行中的数据,而不是data属性的值,所以就算data中有你想要的值,但你没有给他一列的话也是获取不到的),可以在render中直接使用你想隐藏的值,如果表格外部要引用这个值,可以在render中组装一个隐藏的<input>,外部就可以获取到了,不过这种方法真的非常蠢,如果你有好的方法,请一定要告诉我。

输入页码跳转页面

我们可以通过 pagingType 属性来设置表格分页按钮样式,但是DataTables的几个默认样式都没有项目中需要的输入页码进行跳转的样式。但是在官网的 plug-in 页中介绍了几种分页按钮的插件,其中的 input 分页插件就可以满足我们的需求,只要引入插件的js,再将 pagingType 的值改为 "input" 就可以了。js文件的 CDN 是:

//cdn.datatables.net/plug-ins/1.10.11/pagination/input.js

关于其他样式的分页插件参考这里

其他

DataTables是一个非常强大的表格插件,虽说上手比较慢。我用的版本是 1.10 ,在我接手项目的时候项目中用的还是1.9,结果所有参数、API采用匈牙利命名规则,名前都莫名其妙的加上了几个字母前缀,很难理解,在 1.10 版本后就改为驼峰命名规则,人性化多了。要看1.9.x和1.10.x参数名对照请点这里,要查找 1.9.x 的文档请点这里。

参考

DataTables 官网
DataTables 中文网
1.10.x与1.9.x参数名对照表
1.9.x 文档

转载于:https://www.cnblogs.com/jisakun/p/5333325.html

jQuery DataTables 插件使用笔记相关推荐

  1. 自定义ajax脚本出粗哦,jQuery DataTables插件自定义Ajax分页实例解析

    一.问题描述 园友是做前端的,产品经理要求他使用jQuery DataTables插件显示一个列表,要实现分类效果. 后端的分页接口已经写好了,不涉及条件查询,需要传入页码(pageNo)和页面显示数 ...

  2. datatables增删改查php,jQuery+datatables插件实现Ajax加载数据与增删改查功能示例_白峰_前端开发者...

    本文实例讲述了 这里给大家分享一下我在项目中用datatables实现ajax加载数据与增删改查 注意,需要引入  搜索  新增  编辑  删除 职业姓名性别爱好 //点击查找 $(" ...

  3. 使用jquery datatables插件遇到fnReloadAjax的问题

    1 官网地址:http://www.datatables.net/ 2 基本参数介绍 http://blog.csdn.net/mickey_miki/article/details/8240477 ...

  4. 【部分原创】jquery图表插件flot笔记

    Flot是纯Javascript实现的基于jQuery的图表插件,主要支持线状图和柱状图的绘制(通过插件也可以支持饼状图). 它的特点是使用简单.图形美观,支持鼠标跟踪及缩放功能. Flot是基于ca ...

  5. JQuery DataTables插件汉化

    $('#example').dataTable({"bProcessing":true,"sPaginationType":"full_numbers ...

  6. ASP.NETmvc常用JQUERY插件【jquery.dataTables.js】

    离开WEBFORM 也就离开了大量的前端困境,刚一开始用MVC,真感觉好像在沙漠中行走,很想念以前的控件,都快想死了,很快发现原来JQUERY 有很多插件可以用,只怪自己平时不收集,用的时候才手忙脚乱 ...

  7. jquery datatables 学习笔记

    最近项目中用到了BootStrap做后台,在选择表格插件的时候发现了jquery datatables. 功能是很强大,但是网上的例子比较少.在经过一段时间的努力可算是搞出来了. 官网地址:http: ...

  8. Jquery 表格插件DataTables

    [转]Jquery 表格插件DataTables 博客分类: Jquery jquerydatatablesjavascript  1.特性 可变长度分页: 动态过滤: 多列排序,带数据类型检测功能: ...

  9. jQuery的DataTables插件的使用方法[转]

    转自:http://www.guoxk.com/node/jquery-datatables 在做后台的时候并没有美工和前端工程师来配合你做页面,为了显示数据并有一定的美感,我们可以使用jQuery的 ...

最新文章

  1. 阿里云域名注册和虚拟云主机
  2. python 倒叙 数组_打基础一定要吃透这12类 Python 内置函数
  3. 47. Leetcode 107 - 二叉树的层次遍历 ii (二叉树-二叉树遍历)
  4. 子之错父之过什么意思_胎教是什么意思?胎教有何意义?
  5. Leetcode题库 144.二叉树的前序遍历(递归 C实现)
  6. 放弃 Windows 后 ,开源操作系统能成为主流桌面系统吗?
  7. Linux 命令之 file 命令-识别文件类型
  8. javascript 中使用JSON
  9. 零代码以“王者荣耀”为例解析设计七原则
  10. 「小程序JAVA实战」小程序 loading 提示框与页面跳转(37)
  11. 取消setfill_9.1.7 setFillBefore方法:设置起始填充
  12. 微型计算机强化训练的答案,微型计算机第8章+强化训练
  13. 优化CUDA数据传输
  14. f2fs学习笔记 - 8. f2fs 读文件
  15. 各种调试接口(SWD、JTAG、Jlink、Ulink、STlink)的区别
  16. 获得《软件方法》代金券的同学列表-漏了麻烦告知
  17. 生成扩散模型漫谈:DDIM = 高观点DDPM
  18. case when 嵌套
  19. meanshift聚类算法跟踪原理
  20. cnn实现手写识别字体代码详解

热门文章

  1. pycharm写python字典_pycharm_字典
  2. execve系统调用_Linux操作系统中的namespace是个什么鬼
  3. mac weka连接mysql_weka连接mysqllinux
  4. python全栈开发网络_Python 全栈开发:网络编程
  5. 计算机游戏攻略67,保卫萝卜2 67攻略水晶萝卜详解
  6. python dataframe 重命名列_Python-重命名pandas列
  7. 机箱一直反复开机熄火_小身材大容量,老炮九州风神魔方110机箱+DQ 650ST+玄冰400双刃装机体验...
  8. 县级外业调查及举证软件_我公司中标江西省第三次全国国土调查县级建库软件项目...
  9. 集群资源分配_推荐一款MySQL日常运维和集群管理的自动化平台--Arkcontrol
  10. 使用了无效的sql语句_使用SQL语句创建数据库