jQuery dataTables四种数据来源[转]
四种数据来源
对于 dataTables 来说,支持四种表格数据来源。
最为基本的就是来源于网页,网页被浏览器解析为 DOM 对象,在 dataTables 中称为 DOM 来源。
$(document).ready(function() { |
$('#example').dataTable(); |
} ); |
第二种数据来源为数组, JavaScript 中的数组,通过在初始化对象中传递一个名为 aaData 的数组,同样可以提供表格数据,前缀 aa 说明这是一个数组的数组,外层的数组表示表格的行,每一行同样是一个数组。
$(document).ready(function() { |
$('#demo').html( '<table cellpadding="0" cellspacing="0" border="0" class="display" id="example"></table>' ); |
$('#example').dataTable( { |
"aaData": [ |
/* Reduced data set */ |
[ "Trident", "Internet Explorer 4.0", "Win 95+", 4, "X" ], |
[ "Trident", "Internet Explorer 5.0", "Win 95+", 5, "C" ], |
[ "Trident", "Internet Explorer 5.5", "Win 95+", 5.5, "A" ], |
[ "Trident", "Internet Explorer 6.0", "Win 98+", 6, "A" ], |
[ "Trident", "Internet Explorer 7.0", "Win XP SP2+", 7, "A" ], |
[ "Gecko", "Firefox 1.5", "Win 98+ / OSX.2+", 1.8, "A" ], |
[ "Gecko", "Firefox 2", "Win 98+ / OSX.2+", 1.8, "A" ], |
[ "Gecko", "Firefox 3", "Win 2k+ / OSX.3+", 1.9, "A" ], |
[ "Webkit", "Safari 1.2", "OSX.3", 125.5, "A" ], |
[ "Webkit", "Safari 1.3", "OSX.3", 312.8, "A" ], |
[ "Webkit", "Safari 2.0", "OSX.4+", 419.3, "A" ], |
[ "Webkit", "Safari 3.0", "OSX.4+", 522.1, "A" ] |
], |
"aoColumns": [ |
{ "sTitle": "Engine" }, |
{ "sTitle": "Browser" }, |
{ "sTitle": "Platform" }, |
{ "sTitle": "Version", "sClass": "center" }, |
{ |
"sTitle": "Grade", |
"sClass": "center", |
"fnRender": function(obj) { |
var sReturn = obj.aData[ obj.iDataColumn ]; |
if ( sReturn == "A" ) { |
sReturn = "<b>A</b>"; |
} |
return sReturn; |
} |
} |
] |
} ); |
} ); |
aoColumns 参数用来定义表格的列,这是一个数组,其中的每一个对象用来定义一列。
对于每一个列对象:
sTitle 定义列的标题
sClass 定义列的样式
fnRender 函数用来渲染列,这个函数将会传递一个参数对象,这个参数对象的 iDataColumn 属性表示当前的列索引,aData 表示当前的行数组。函数返回的结果将被填充到单元格中。
当然了,对于表示行的数组来说,长度应该是相同的。如果某一行数据缺失或者提供了过多地数据的话,就会得到一个警告。

第三种数据来源是 AJAX,也就是说可以向服务器发一个请求来获得数据。
在初始化参数对象中,通过 sAjaxSource 的属性传递请求的地址,bProcessing 表示是否需要显示一个工作中的提示。
在 JSON 方式返回的数据中,需要一个名为 aaData 的属性来提供实际的数据。
$(document).ready(function() { |
$('#example').dataTable( { |
"bProcessing": true, |
"sAjaxSource": '../examples_support/json_source.txt' |
} ); |
} ); |
其中 json_source.txt 就是 JSON 数据,其中定义了一个名为 aaData 的属性。这个文件可以在下载的压缩包中找到,在 examples\examples_support 文件夹中。
最后一种数据来源是服务器,对于大量的数据来说,你可能希望在服务器端完成所有的操作,分页、排序、过滤等等。dataTable 可以通过服务器完成这些功能,甚至其他的服务器,像 Google Gears 或者 Adobe Air,这样的话,dataTables 就是一个显示数据和提供操作事件的前端模块。
$(document).ready(function() { |
$('#example').dataTable( { |
"bProcessing": true, |
"bServerSide": true, |
"sAjaxSource": "../examples_support/server_processing.php" |
} ); |
} ); |
对于服务器来说,可以通过请求参数来获得当前的操作信息。
| 类型 | 名称 | 说明 |
| int | iDisplayStart | 显示的起始索引 |
| int | iDisplayLength | 显示的行数 |
| int | iColumns | 显示的列数 |
| string | sSearch | 全局搜索字段 |
| boolean | bEscapeRegex | 全局搜索是否正则 |
| boolean | bSortable_(int) | 表示一列是否在客户端被标志位可排序 |
| boolean | bSearchable_(int) | 表示一列是否在客户端被标志位可搜索 |
| string | sSearch_(int) | 个别列的搜索 |
| boolean | bEscapeRegex_(int) | 个别列是否使用正则搜索 |
| int | iSortingCols | 排序的列数 |
| int | iSortCol_(int) | 被排序的列 |
| string | sSortDir_(int) | 排序的方向 "desc" 或者 "asc". |
| string | sEcho | DataTables 用来生成的信息 |
这篇文章介绍了在 C# 中结合 LINQ 使用 DataTables 进行服务端处理的经验 jQuery DataTables Plugin Meets C#
服务器应该返回如下的 JSON 格式数据
| 类型 | 名称 | 说明 |
| int | iTotalRecords | 实际的行数 |
| int | iTotalDisplayRecords | 过滤之后,实际的行数。 |
| string | sEcho | 来自客户端 sEcho 的没有变化的复制品, |
| string | sColumns | 可选,以逗号分隔的列名, |
| array array mixed | aaData | 数组的数组,表格中的实际数据。 |
服务器返回的数据示例如下:
{ |
"sEcho": 3, |
"iTotalRecords": 57, |
"iTotalDisplayRecords": 57, |
"aaData": [ |
[ |
"Gecko", |
"Firefox 1.0", |
"Win 98+ / OSX.2+", |
"1.7", |
"A" |
], |
[ |
"Gecko", |
"Firefox 1.5", |
"Win 98+ / OSX.2+", |
"1.8", |
"A" |
], |
... |
] |
} |
转载于:https://my.oschina.net/u/2260184/blog/540577
jQuery dataTables四种数据来源[转]的更多相关文章
- iOS中常用的四种数据持久化方法简介
iOS中常用的四种数据持久化方法简介 iOS中的数据持久化方式,基本上有以下四种:属性列表.对象归档.SQLite3和Core Data 1.属性列表涉及到的主要类:NSUserDefaults,一般 ...
- Python中xml、字典、json、类四种数据的转换
最近学python,觉得python很强很大很强大,写一个学习随笔,当作留念注:xml.字典.json.类四种数据的转换,从左到右依次转换,即xml要转换为类时,先将xml转换为字典,再将字典转换为j ...
- Oracle数据库四种数据完整性约束
Oracle数据库四种数据完整性约束 1.实体完整性 同样的数据不能重复插入(1)采取什么措施保证实体完整性?我们可以给表创建主键约束吗,主键保证了数据的唯一性,主键可以保证同一条记录只能插入一次. ...
- 【hive】——Hive四种数据导入方式
Hive的几种常见的数据导入方式这里介绍四种:(1).从本地文件系统中导入数据到Hive表:(2).从HDFS上导入数据到Hive表:(3).从别的表中查询出相应的数据并导入到Hive表中:(4).在 ...
- iOS中常用的四种数据持久化技术
iOS中的数据持久化方式,基本上有以下四种:属性列表 对象归档 SQLite3和Core Data 1.属性列表涉及到的主要类:NSUserDefaults,一般 [NSUserDefaults st ...
- Jquery DataTables 获取表格数据及行数据
注意table变量是 1.jQuery DataTables 行号获取 $("#example tbody tr").on("click", function( ...
- Hive四种数据导入方式介绍
问题导读 1.从本地文件系统中通过什么命令可导入数据到Hive表? 2.什么是动态分区插入? 3.该如何实现动态分区插入? 扩展: 这里可以和Hive中的三种不同的数据导出方式介绍进行对比? Hive ...
- 013-HQL中级3-Hive四种数据导入方式介绍
Hive的几种常见的数据导入方式这里介绍四种:(1).从本地文件系统中导入数据到Hive表:(2).从HDFS上导入数据到Hive表:(3).从别的表中查询出相应的数据并导入到Hive表中:(4).在 ...
- jQuery中四种事件监听的区别
原文链接:点我 我们知道jquery提供了四种事件监听方式,分别是bind.live.delegate.on,下面就分别对这四种事件监听方式分析. 已知有4个列表元素: 列表元素1 列表元素2 列表元 ...
随机推荐
- C语言:static关键字用法
参考博客:https://blog.csdn.net/guotianqing/article/details/79828100 看个例子: #include <stdio.h> void ...
- 分享淘宝时间服务器同步时间接口api和苏宁时间服务器接口api
最近要开发一款抢购秒杀的小工具,需要同步系统时间,这里分享两个时间服务器接口api给大家: 1.淘宝时间服务器时间接口 http://api.m.taobao.com/rest/api3.do?api ...
- 在docker中部署redis主从配置
环境说明: 阿里云服务器 Ubuntu 16.04 docker 1.拉取Redis镜像 docker pull redis 2.配置Redis启动配置文件,此处我创建一个专用目录,存放Redis相关 ...
- app测试的一些较为重要的测试点
安装测试 从不同的手机所自带的不同的版本的软件商城里面下载抖音并安装查看是否成功 安装后是否能正常运行安装后的文件和文件夹是否写到了指定的目录里 安装过程中取消安装,安装的文件是否在指定的目录里 安装 ...
- alembic的常用参数
alembic的常用参数 命令和参数解释 1 .init:创建一个alembic仓库. 2 .revision:创建一个新的版本文件. 3 .--autogenerate:自动将当前的模型修改,生成迁 ...
- 28.4 Calendar 日历
/* * Calendar:日历,提供了一些操作年月日时的方法 * 获取 * 修改 * 添加 */ public class CalendarDemo { public static void mai ...
- C++线性表的链式存储结构
C++实现线性表的链式存储结构: 为了解决顺序存储不足:用线性表另外一种结构-链式存储.在顺序存储结构(数组描述)中,元素的地址是由数学公式决定的,而在链式储存结构中,元素的地址是随机分布的,每个元素 ...
- 页面存在多个url,使用jmeter进行遍历操作
有一次遇见一个问题:进入网站后,有多个相同的url,但是仅url后面的路径中id有区别,如下图:这时我想要遍历点击查看url详情内容:那么就可以使用一个“逻辑控制器---foreach控制器” 如下: ...
- java中JVM虚拟机内存模型详细说明
java中JVM虚拟机内存模型详细说明 2012-12-12 18:36:03| 分类: JAVA | 标签:java jvm 堆内存 虚拟机 |举报|字号 订阅 JVM的内部结构 ...
- Java成长第三集--基础重点详细说明
接上篇文章,继续阐述相关的重点基础知识,话不多说! 一.Java中equals()和“==”区别 1.对于8种基础数据类型,使用“=="比较值是否相等: 2.对于复合数据类型(类),使用eq ...
