本文是jquery<--json-->spring(3.0)系列的第三篇。
原文地址:http://blog.csdn.net/hy840429/article/details/5626878
jquery与yui相比,感觉写法很简洁,但也有个问题是配套的jquery ui中的页面控件
不是很全,很多要借助plugin,而这些plugin良莠不齐,选用时要自己好好挑一挑。
列表是一个常用的页面控件,我选了半天发现DataTables这款用的人比较多,就试了
试服务器端翻页功能,现总结如下。
DataTables的主页是http://www.datatables.net/
先上个这个demo的截图,设想的操作是输入客户名称,按检索后进行模糊检索进行分
页显示,每页显示8条记录。
1 页面部分
使用DataTables时,html需要如下书写,其中tfoot部分是表表格的下部标题,可以不
要。
- <table class="display" id="customerInfo">
-
<thead>
-
<tr>
-
<th>ID</th>
- 略
-
<th>身高</th>
-
</tr>
-
</thead>
-
<tbody>
-
<tr>
-
<td colspan="8"></td>
-
</tr>
-
</tbody>
-
<tfoot>
-
<tr>
-
<th>ID</th>
- 略
-
<th>身高</th>
-
</tr>
-
</tfoot>
-
</table>
js部分这样写:
- $('#customerInfo').dataTable();
对于从服务器端取数据,还要指定几个参数:
bServerSide:true
sAjaxSource:获取数据的url
这样,在DataTables需要数据时会调用jquery的getJSON获取数据,其中url就是sAjaxSource,
同时传递一堆自定义的参数,包括需要显示的起始记录数,需要显示的记录数,列数,排序
列等等,具体可以参看这里http://www.datatables.net/usage/server-side。其中一个比较
特殊的是sEcho,这个参数需要以后原封不动地返回给页面。
由于默认是以$.getJSON发送请求,所以http命令是GET,参数是以url参数的方式传递的,我
希望以POST命令,以json方式发送请求,而且要加上客户名称这个参数,所以这里需要做些修
改。
DataTables通过fnServerData提供了这样一个接口,fnServerData是与服务器端交换数据时被
调用的函数,默认实现是如上所说的通过getJSON发送请求,然后接收特定格式的json数据(这
个在服务器端处理部分再说)。fnServerData会接到3个参数:
sSource: 接收数据的url,就是sAjaxSource中指定的地址
aoData:DataTables定义的参数,是一个数组,其中每个元素是一个name-value对,我需要
把客户名称这个参数加进去
fnCallback:服务器返回数据后的处理函数,我需要按DataTables期望的格式传入返回数据
最后自定义的fnServerData如下所示:
- function retrieveData( sSource, aoData, fnCallback ) {
-
-
aoData.push( { "name": "customerName", "value": $("#customerName").val() } );
-
- $.ajax( {
-
"type": "POST",
-
"contentType": "application/json",
-
"url": sSource,
-
"dataType": "json",
-
"data": JSON.stringify(aoData),
-
"success": function(resp) {
-
fnCallback(resp.returnObject);
- }
- });
- }
页面的初始化及查询按钮的处理函数如下所示:
- var oTable = null;
-
-
$(function() {
-
$("#customerInfo").hide();
- } );
-
-
-
function search() {
-
if (oTable == null) {
-
$("#customerInfo").show();
-
oTable = $('#customerInfo').dataTable( {
-
"bAutoWidth": false,
-
"aoColumns": [
-
{"sWidth": "15px"},
-
{"sWidth": "80px"},
-
{"sWidth": "160px"},
-
{"sWidth": "110px"},
-
{"sWidth": "120px"},
-
{"sWidth": "140px"},
-
{"sWidth": "140px"},
-
{"sWidth": "*"}
- ],
-
"bProcessing": true,
-
"bServerSide": true,
-
"bFilter": false,
-
"bLengthChange": false,
-
"iDisplayLength": 8,
-
"sAjaxSource": "customerInfo/search.do",
-
"fnServerData": retrieveData,
-
"sPaginationType": "full_numbers",
-
"oLanguage": {
-
"sLengthMenu": "每页显示 _MENU_ 条记录",
-
"sZeroRecords": "没有检索到数据",
-
"sInfo": "当前数据为从第 _START_ 到第 _END_ 条数据;总共有 _TOTAL_ 条记录",
-
"sInfoEmtpy": "没有数据",
-
"sProcessing": "正在加载数据...",
-
"oPaginate": {
-
"sFirst": "首页",
-
"sPrevious": "前页",
-
"sNext": "后页",
-
"sLast": "尾页"
- }
- }
- });
- }
-
-
- oTable.fnDraw();
- }
2 服务器端
页面请求的参数是一个数组,其中每个元素是一个name-value对,我如下定义
- public class JSONParam {
-
private String name;
-
private String value;
-
-
- }
对应的处理函数如下定义:
- @RequestMapping(value = "/search", method = RequestMethod.POST)
-
@ResponseBody
-
public JSONResponse search(@RequestBody JSONParam[] params){
-
- }
在这个函数里大致的处理是先取出所需的参数,然后检索数据,最后将DataTables期望的
格式的数据放入返回对象JSONResponse的returnObject部分。
DataTables期望的数据格式如下:
{
"sEcho": 页面发来的参数,原样返回,
"iTotalRecords": 过滤前总记录数,
"iTotalDisplayRecords": 过滤后总记录数,我没有使用过滤,不太清楚和iTotalRecords的区别,
"aaData": 包含数据的2维数组
}
对应的java定义如下:
- public class DataTableReturnObject {
-
private long iTotalRecords;
-
private long iTotalDisplayRecords;
-
private String sEcho;
-
private String[][] aaData;
-
-
public DataTableReturnObject(long totalRecords, long totalDisplayRecords, String echo, String[][] d) {
-
- }
-
-
- }
完整的服务器端处理函数如下:
- @RequestMapping(value = "/search", method = RequestMethod.POST)
-
@ResponseBody
-
public JSONResponse search(@RequestBody JSONParam[] params) throws IllegalAccessException, InvocationTargetException
-
- HashMap<String, String> paramMap = convertToMap(params);
-
String sEcho = paramMap.get("sEcho");
-
String customerName = paramMap.get("customerName");
-
int start = Integer.parseInt(paramMap.get("iDisplayStart"));
-
int length = Integer.parseInt(paramMap.get("iDisplayLength"));
-
-
-
- List<Object> customerList = customerService.search(customerName, start, length);
-
Long count = (Long)customerList.get(0);
-
-
-
int record = customerList.size() - 1;
-
String[][] data = new String[record][];
-
for(int i=0; i<record; i++) {
-
Customer customer = (Customer)customerList.get(i+1);
-
JSONCustomer jsonCustomer = new JSONCustomer();
- BeanUtils.copyProperties(jsonCustomer, customer);
- data[i] = jsonCustomer.toArray();
- }
-
-
return successed(new DataTableReturnObject(count.longValue(), count.longValue(), sEcho, data));
- }
数据返回到页面后,如上所述,取出response中的returnObject交给DataTables的函数进行处理
就可以了
分享到:
相关推荐
WIP:Laravel DataTables资产DataTables服务器端和客户端脚本的个人集合。 注意:脚本依赖于bootstrap 4样式。 使用风险自负。 :)安装yarn add https://github.com/yajra/laravel-datatables-assets 按钮资产require...
在本项目"labs-datatables-vraptor"中,我们探讨了如何使用Java和VRaptor框架进行DataTables的服务器端处理。DataTables是一个流行的JavaScript库,它增强了HTML表格的功能,提供了排序、过滤、分页和数据可视化等...
codeigniter-datatables, PHP sql server服务器端的jQuery数据表 datatablesPHP sql server服务器端的jQuery数据表这里代码被设计用于在使用Codeigniter时,用于流行的jQuery datatable插件的服务器端部分。...
在“dataTables导出功能”这个主题中,我们关注的是DataTables的一个关键特性:导出功能。这个特性允许用户将表格数据导出为多种格式,如CSV、PDF或Excel,方便数据存储和进一步分析。 DataTables的导出功能通常...
- **数据加载**:支持服务器端处理和客户端处理两种模式,可根据数据量选择合适的加载方式。 - **自定义列**:用户可以隐藏或显示特定列,甚至调整列宽,以适应不同的显示需求。 - **扩展性**:提供多种插件和API...
创建一个新控制器,用于处理datatables的服务器端请求。在Laravel 4中,你可以使用`Artisan`命令生成控制器: ``` php artisan controller:make DataTablesController ``` 在新生成的控制器中,你将定义用于...
`DataTables`本身支持Ajax数据源,允许从服务器端动态获取数据并显示在表格中。然而,当你需要在用户操作后(如筛选、排序或过滤)即时更新表格数据时,`fnReloadAjax`插件就派上用场了。这个插件能够便捷地触发表格...
**jQuery DataTables 服务器端分页详解** jQuery DataTables 是一款功能强大的JavaScript库,用于将HTML表格转化为交互式数据视图。服务器端分页(Server-side pagination)是其核心特性之一,尤其适用于处理大量...
本篇文章将深入探讨如何结合Vue和DataTables实现服务器端分页的实例。 首先,我们要理解服务器端分页的概念。与客户端分页不同,服务器端分页在服务器上执行数据过滤、排序和分页逻辑,而不是在浏览器端。这样做...
1. **分页**:DataTables 提供了服务器端和客户端两种分页模式。服务器端分页在每次改变页码或搜索条件时向服务器发送请求,获取当前页的数据;客户端分页则将所有数据一次性加载到客户端,然后进行本地处理。这个...
开发工具 dataTables.bootstrap.min开发工具 dataTables.bootstrap.min开发工具 dataTables.bootstrap.min开发工具 dataTables.bootstrap.min开发工具 dataTables.bootstrap.min开发工具 dataTables.bootstrap.min...
此外,它还支持服务器端处理,这意味着数据的获取和更新可以在服务器端进行,降低了前端的负担。 在主题和样式上,Datatables可以轻松融入各种网页设计。它内置了多种预设主题,如Bootstrap、Foundation等,也可以...
DataTables支持多种数据源,包括HTML表格数据、服务器端数据(Ajax)和JSON对象。在本例中,假设数据已内置于HTML表格中,无需额外配置。 3. **功能定制** DataTables提供很多可选参数以定制其行为。例如,可以...
此外,Datatables的服务器端处理模式使得它能够处理大量数据,减轻前端的压力,同时也支持用户操作(如筛选、排序)直接反映到数据库上。 在压缩包中的“Datatables bootstrap4”文件,可能包含以下内容: 1. HTML...
jQuery Datatables服务器端处理 ASP NET组件,为著名的jQuery表插件添加了自动服务器端处理功能。 它使用IQueryable接口来构造查询表达式到您的数据集合,可以由诸如实体框架的ORM处理。 支持: 分页; 搜索; ...
DRF数据表示例服务器端此版本为django <2> 2.0,请参考DataTables示例(服务器端)-Python Django REST框架-建议看影片的demo说明DataTables(服务器端)搭配简单范例 :memo:特色使用建立API。搭配使用增加用户体验...
3. **服务器端处理**:对于大量数据,DataTables支持服务器端处理模式,只加载当前页面所需的数据,减轻了前端的负担,提高了页面加载速度和性能。 4. **自定义列和数据**:开发者可以自定义每列的显示内容和样式,...
DataTables支持多种数据源,包括DOM、Ajax、服务器端处理和JSON对象。例如,通过Ajax加载数据: ```javascript $('#example').DataTable({ "processing": true, "serverSide": true, "ajax": "scripts/server_...