Jquery Datatables(三)
最近在项目中又使用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(三)的更多相关文章
- [jQuery]jQuery DataTables插件自定义Ajax分页实现
前言 昨天在博客园的博问上帮一位园友解决了一个问题,我觉得有必要记录一下,万一有人也遇上了呢. 问题描述 园友是做前端的,产品经理要求他使用jQuery DataTables插件显示一个列表,要实现分 ...
- jQuery datatables
jQuery datatables 属性,用例 参考:http://datatables.club/example/ http://blog.csdn.net/mickey_miki/article/ ...
- jQuery DataTables 插件使用笔记
初始化 在页面中 <!DOCTYPE html> <html> <head> <link rel="stylesheet" type=&q ...
- JQuery Datatables(一)
最近项目中用了Bootstrap的样式风格,控件用了JQuery Datatables,主要有几下几点目标: 实现BootStrap风格的table,使用Ajax获取数据,并有勾选项 可以实现全选,单 ...
- JQuery DataTables Editor---只修改页面内容
近来在工作中需要对JQuery DataTables进行增,删,改的操作,在网上找了一些资料,感觉比较的好的就是(http://editor.datatables.net/)文章中所展示的操作方法(如 ...
- jquery datatables api (转)
学习可参考:http://www.guoxk.com/node/jquery-datatables http://yuemeiqing2008-163-com.iteye.com/blog/20069 ...
- 最全的jquery datatables api 使用详解
学习可参考:http://www.guoxk.com/node/jquery-datatables http://yuemeiqing2008-163-com.iteye.com/blog/20069 ...
- jquery datatables api
原文地址 学习可参考:http://www.guoxk.com/node/jquery-datatables http://yuemeiqing2008-163-com.iteye.com/blog/ ...
- jQuery dataTables四种数据来源[转]
2019独角兽企业重金招聘Python工程师标准>>> 四种数据来源 对于 dataTables 来说,支持四种表格数据来源. 最为基本的就是来源于网页,网页被浏览器解析为 DOM ...
随机推荐
- 求奇数偶数的和,,利用while循环
static void Main(string[] args) { while (true) { try ...
- 一起啃PRML - 1.1 Example: Polynomial Curve Fitting 多项式曲线拟合
一起啃PRML - 1.1 Example: Polynomial Curve Fitting @copyright 转载请注明出处 http://www.cnblogs.com/chxer/ 前言: ...
- Beta Round #9 (酱油杯noi考后欢乐赛)PLQ的寻宝
题目:http://www.contesthunter.org/contest/Beta%20Round%20%EF%BC%839%20%28%E9%85%B1%E6%B2%B9%E6%9D%AFno ...
- App架构经验总结(转)
原文链接: http://keeganlee.me/post/architecture/20160303 架构因人而异,不同的架构师大多会有不同的看法:架构也因项目而异,不同的项目需求不同,相应的架构 ...
- 计算几何(凸包):SHTSC 2012 信用卡凸包
这道题是水题,发现平移某些边,答案就是圆心的凸包+一个圆的周长. 不要忽视精度误差! #include <algorithm> #include <iostream> #inc ...
- Oracle体系结构图
1 oracle数据库主要有数据文件database和数据库实例instance组成.用户通过用户进程链接到server process.在数据库启动的时候,需要依赖于参数文件parameter fi ...
- [GRYZ2014]最大连续子序列的和
求给定序列的最大连续子序列和. 输入:第一行:n(n<100000) 第二行:n个整数[-3000,3000]. 输出:最大连续子序列的和. 样例: 输入: 7 -6 4 ...
- Kbuild文件
3 Kbuild文件 大部分内核中的Makefile都是使用Kbuild组织结构的Kbuild Makefile.这章将介绍Kbuild Makefile的语法. 对于Kbuild文件名来讲,Kbui ...
- wDatePicker使用说明文档
版权声明:本文为博主原创文章,未经博主允许不得转载. http://www.my97.net/dp/demo/ 4.5更新的内容 [重构]对WdatePicker.js做了较大规模的调整 [改进]自动 ...
- ReactiveCocoa框架学习2
昨天内容回顾 信号类:表示有数据产生,信号类不发送数据 注意:不同的信号,订阅方式不同 RACSignal 创建RACDynamicSignal信号 -> didSubscribe(block) ...