最近在项目中又使用Datatables的一个有趣功能,官网列子如下图:

点击“+”,展开列表,再次点击收缩。

官网的列子点击展开后的数据也是原来行中的数据,这边有了一个想法是否可以利用Ajax去动态加载数据,让“+”实现主从表的功能?

分析后觉得可以,动手实验。

首先,敲代码去实现不带“+”的表格,这个应该很简单。

然后加入一列,让第一列展示一个“+”图片。

     var table = $('#example').DataTable({
"bSort": false, //排序设置为False
"bFilter": false,//搜索设置为False
"sAjaxSource": "/XXXX/XXXX/XXXX",
"aoColumns": [
{
"mDataProp": "Id",
"className": 'details-control', //运用样式来加载图片
"render": function (data, type, row) {
return ''; //关键,让第一列什么都不现实
}
},
{
"mDataProp": "Name"
}, { "mDataProp": "WorkDay" }
]
});

Datatables

其中,CSS的样式可以参考官网列子:

 td.details-control {
background: url('../resources/details_open.png') no-repeat center center;
cursor: pointer;
}
tr.shown td.details-control {
background: url('../resources/details_close.png') no-repeat center center;
}

CSS代码

接下来,就是如何让点击“+”时展开并加载数据,添加监听事件:

     //对TR中每行扩展,缩小添加事件
$('#example tbody').on('click', 'td.details-control', function () {
var tr = $(this).closest('tr');
var row = table.row(tr); var employeeId = row.data().EmployeeID;
var workDate = row.data().WorkDate; if (row.child.isShown()) {
row.child.hide();
tr.removeClass('shown');
}
else {
//通过Ajax获取从表信息
$.ajax({
url: "/XX/XXX/XXX",
type: "Get",
data: { "XXX": XXX, "XX": XXX },
success: function (data) {
row.child(format(data)).show();
tr.addClass('shown');
}
});
}
});

添加监听事件

其中format函数需要利用Ajax返回数据实现动态表格也就是用js拼接Html代码:

     //动态添加表格
function format(data) {
var total = data.total; //通过JSON数据创建table表
var tableHtml = '<div class="row"><div class="col-sm-1"></div><div class="col-sm-11"><table class="table table-striped table-condensed table-bordered table-hover"><thead>' +
'<tr><td>XXX</td><td>XXX</td><td>XXX</td><td>XXX</td><td>XXX</td><td></td></tr></thead>';
for (var i = 0; i < total; i++) {
var d = data.data[i];
if(i%2==0){//隔行颜色不同设置
tableHtml += '<tr class="success">';
} else
{
tableHtml += '<tr>'
}
tableHtml +=
'<td style="vertical-align: middle">' + d.XXX.substr(0, 10) + '</td>' +
'<td style="vertical-align: middle">' + d.XXX + '</td>' +
'<td style="vertical-align: middle">' + d.XXX + '</td>' +
'<td style="vertical-align: middle">' + d.XXX + '</td>' +
'<td style="vertical-align: middle">' + d.XXX + '</td>' +
'<td style="vertical-align: middle"><button class="btn btn-danger btn-xs" type="btn" onclick="deleteItem(\'' + d.Id + '\')">删除</button></td>' +
'</tr>';
}
tableHtml += '</table></div></div>';
return tableHtml;
}

动态拼接表格

Jquery Datatables(三)的更多相关文章

  1. [jQuery]jQuery DataTables插件自定义Ajax分页实现

    前言 昨天在博客园的博问上帮一位园友解决了一个问题,我觉得有必要记录一下,万一有人也遇上了呢. 问题描述 园友是做前端的,产品经理要求他使用jQuery DataTables插件显示一个列表,要实现分 ...

  2. jQuery datatables

    jQuery datatables 属性,用例 参考:http://datatables.club/example/ http://blog.csdn.net/mickey_miki/article/ ...

  3. jQuery DataTables 插件使用笔记

    初始化 在页面中 <!DOCTYPE html> <html> <head> <link rel="stylesheet" type=&q ...

  4. JQuery Datatables(一)

    最近项目中用了Bootstrap的样式风格,控件用了JQuery Datatables,主要有几下几点目标: 实现BootStrap风格的table,使用Ajax获取数据,并有勾选项 可以实现全选,单 ...

  5. JQuery DataTables Editor---只修改页面内容

    近来在工作中需要对JQuery DataTables进行增,删,改的操作,在网上找了一些资料,感觉比较的好的就是(http://editor.datatables.net/)文章中所展示的操作方法(如 ...

  6. jquery datatables api (转)

    学习可参考:http://www.guoxk.com/node/jquery-datatables http://yuemeiqing2008-163-com.iteye.com/blog/20069 ...

  7. 最全的jquery datatables api 使用详解

    学习可参考:http://www.guoxk.com/node/jquery-datatables http://yuemeiqing2008-163-com.iteye.com/blog/20069 ...

  8. jquery datatables api

    原文地址 学习可参考:http://www.guoxk.com/node/jquery-datatables http://yuemeiqing2008-163-com.iteye.com/blog/ ...

  9. jQuery dataTables四种数据来源[转]

    2019独角兽企业重金招聘Python工程师标准>>> 四种数据来源 对于 dataTables 来说,支持四种表格数据来源. 最为基本的就是来源于网页,网页被浏览器解析为 DOM ...

随机推荐

  1. 详解Makefile 函数的语法与使用

    使用函数: 在Makefile中可以使用函数来处理变量,从而让我们的命令或是规则更为的灵活和具有智能.make所支持的函数也不算很多,不过已经足够我们的操作了.函数调用后,函数的返回值可以当做变量来使 ...

  2. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(1)-前言与目录(持续更新中...)

    转自:http://www.cnblogs.com/ymnets/p/3424309.html 曾几何时我想写一个系列的文章,但是由于工作很忙,一直没有时间更新博客.博客园园龄都1年了,却一直都是空空 ...

  3. (转载)C++中, 构造函数和析构函数能不能被显示调用?

    (转载)http://blog.csdn.net/zhangxinrun/article/details/6056321 代码: view plaincopy to clipboardprint?#i ...

  4. android学习——activity的生命周期

    Android中主要组件之Activity的生命周期,基本都是翻译Android API和个人的理解. 首先看一下Android api中所提供的Activity生命周期图: Activity其实是继 ...

  5. MD5加密函数

    CREATE OR REPLACE FUNCTION MD5( passwd IN VARCHAR2) RETURN VARCHAR2 IS retval ); BEGIN retval := utl ...

  6. Ext.MessageBox的用法

    1.Ext.MessageBox.alert()方法 有四个参数:alert( title , msg , function(){} ,this) 其中title,msg为必选参数,function为 ...

  7. java基础(十四)集合(一)

    这里有我之前上课总结的一些知识点以及代码大部分是老师讲的笔记 个人认为是非常好的,,也是比较经典的内容,真诚的希望这些对于那些想学习的人有所帮助! 由于代码是分模块的上传非常的不便.也比较多,讲的也是 ...

  8. php中的variables_order

    PHP中的$_ENV是一个包含服务器端环境变量的数组.它是PHP中一个超级全局变量,我们可以在PHP 程序的任何地方直接访问它.     $_ENV只是被动的接受服务器端的环境变量并把它们转换为数组元 ...

  9. OpenSUSE SuSEfirewall2

    1,修改SuSEfirewall2配置文件放行相应的端口方法vim /etc/sysconfig/SuSEfirewall2#TCP端口的情况:FW_SERVICES_EXT_TCP ="2 ...

  10. Yii学习系列:Yii视频讲义——前篇(转)

    1.yii的网址 http://www.yiiframework.com/ yii官方网址 http://www.yiichina.com/ yii中文社区 2.bootstrap的网址 http:/ ...