基于EasyUi的datagrid合并单元格JS写法
$('#dg').datagrid({
width: 'auto',
height: 'auto',
scrollbarSize: ,
queryParams: {},
url: 'kkkk',
columns: [[
{ field: 'bh', title: '编号', width: , sortable: false },
{ field: 'mc', title: '名称', width: , sortable: false },
{ field: 'zf', title: '总分', width: , sortable: false }
]],
nowrap: false,
fitColumns: false,
striped: true,
rownumbers: false, //行号
singleSelect: false, //是否单选
onLoadError: function (e) {
$.messager.alert("提示", "加载失败", "error");
},
onLoadSuccess: function (data) {
var cells = ["kc", "uu"];
mergeCells('dg', data, cells); });
}
}); //第一种
//dg:datagrid的id;data:onLoadSuccess: function (data){}中的data;cellnames:合并的列,var cells = ["ku", "uu"];
function mergeCells(dg, data, cellnames) {
for (var i = ; i < cellnames.length; i++) {
var cellname = cellnames[i];
var merges = [];
for (var r = ; r < data.rows.length; r++) {
var row = data.rows[r];
var mergeinfo = new Object();
var nr = row[cellname];
var rowspan = ;
for (var r1 = r + ; r1 < data.rows.length; r1++) {
var row1 = data.rows[r1];
var nr1 = row1[cellname]; if (nr1 && nr1 == nr && nr1 != "") {
mergeinfo.index = r;
rowspan++;
mergeinfo.rowspan = rowspan;
}
else {
if (rowspan > ) {
merges.push(mergeinfo);
r = r1 - ;
}
break;
}
if (r1 == data.rows.length - ) {
if (rowspan > ) {
merges.push(mergeinfo);
r = r1 - ;
}
}
}
}
for (var j = ; j < merges.length; j++) {
$('#' + dg).datagrid('mergeCells', {
index: merges[j].index,
field: cellname,
rowspan: merges[j].rowspan
});
}
}
} //第二种 function mergeCells_table(dg, data, cellnames) {
var table = document.getElementById(dg);
for (var i = ; i < cellnames.length; i++) {
var cellname = cellnames[i];
var merges = [];
for (var r = ; r < data.rows.length; r++) {
var row = data.rows[r];
var mergeinfo = new Object();
var nr = row[cellname];
var rowspan = ;
for (var r1 = r + ; r1 < data.rows.length; r1++) {
var row1 = data.rows[r1];
var nr1 = row1[cellname]; if (nr1 && nr1 == nr && nr1 != "") {
mergeinfo.index = r;
rowspan++;
mergeinfo.rowspan = rowspan;
table.rows[r + ].cells[i].rowSpan = rowspan;
table.rows[r1 + ].cells[i].style.display = "none";
}
else {
if (rowspan > ) {
merges.push(mergeinfo);
r = r1 - ;
}
break;
}
if (r1 == data.rows.length - ) {
if (rowspan > ) {
merges.push(mergeinfo);
r = r1 - ;
}
}
}
}
// for (var j = 0; j < merges.length; j++) {
// $('#' + dg).datagrid('mergeCells', {
// index: merges[j].index,
// field: cellname,
// rowspan: merges[j].rowspan
// });
// }
}
}
$('#dg').datagrid({
width: '100%',
height: '',
queryParams: {},
loadMsg: '正在加载....',
columns: [[ { field: 'bh', title: '编号', width: , sortable: false },
{ field: 'mc', title: '名称', width: , sortable: false },
{ field: 'zf', title: '总分', width: , sortable: false }
]],
pagination: false, //分页控件
fitColumns: true,
striped: true,
rownumbers: false, //行号
singleSelect: true, //是否单选
onLoadSuccess: function (data) {
var cellcomp = 'bh';
var cells = ['mc', 'zf'];
mergeCells_New('dg', data, cellcomp, cells);
}
}); //dg:datagrid的id;data:onLoadSuccess: function (data){}中的data;cellcomp:列相同;cellnames:合并的列,var cells = ["ku", "uu"];
//cellcomp列相同,cellnames合并
function mergeCells_New(dg, data, cellcomp, cellnames) {
var merges = [];
for (var r = ; r < data.rows.length; r++) {
var row = data.rows[r];
var mergeinfo = new Object();
var nr = row[cellcomp];
var rowspan = ;
for (var r1 = r + ; r1 < data.rows.length; r1++) {
var row1 = data.rows[r1];
var nr1 = row1[cellcomp]; if (nr1 && nr1 == nr && nr1 != "") {
mergeinfo.index = r;
rowspan++;
mergeinfo.rowspan = rowspan;
}
else {
if (rowspan > ) {
merges.push(mergeinfo);
r = r1 - ;
}
break;
}
if (r1 == data.rows.length - ) {
if (rowspan > ) {
merges.push(mergeinfo);
r = r1 - ;
}
}
}
}
for (var i = ; i < cellnames.length; i++) {
var cellname = cellnames[i];
for (var j = ; j < merges.length; j++) {
$('#' + dg).datagrid('mergeCells', {
index: merges[j].index,
field: cellname,
rowspan: merges[j].rowspan
});
}
}
}
基于EasyUi的datagrid合并单元格JS写法的更多相关文章
- JS实现EasyUI ,Datagrid,合并单元格功能
为了实现datagrid的合并单元格效果,datagrid的数据加载方式肯定是要写在JS文件内部的. 一:在JS内部添加Datagrid数据加载方法如下: $("#id").dat ...
- 雷林鹏分享:jQuery EasyUI 数据网格 - 合并单元格
jQuery EasyUI 数据网格 - 合并单元格 数据网格(datagrid)经常需要合并一些单元格.本教程将向您展示如何在数据网格(datagrid)中合并单元格. 为了合并数据网格(datag ...
- Silverlight的DataGrid合并单元格
现在也不知道还有没有同学做Silverlight开发了,我是一个Silverlight菜鸟,遇到问题也很难百度查到.就简单的记录一下这两天遇到的问题,并做了一个简单的小Demo,希望能够帮助到其他同学 ...
- easyui datagrid 合并单元格
整理以前做的东西,这个合并单元格的问题再新浪博客也写过了..... 下面这段代码是列表数据 //载入排放系数管理报表数据 function LoadEmissionReportData() { //获 ...
- easyui 自动动态合并单元格
.......onLoadSuccess : function(data) { if (data.rows.length > 0) { //调用mergeCellsByField()合并单元格 ...
- WPF DataGrid 合并单元格
在网上搜索wpf合并单元格,一直没搜索到,没办法,只能自己想办法搞定了.其实就是DataGrid套DataGrid,为了方便支持Column拖动,在合并的DataGridColumn那一列的Heade ...
- DataGrid合并单元格(wpf)
在网上搜索wpf合并单元格,一直没搜索到,没办法,只能自己想办法搞定了.其实就是DataGrid套DataGrid,为了方便支持Column拖动,在合并的DataGridColumn那一列的Heade ...
- C# DataGrid合并单元格
1.栏位枚举 private enum DataGridColumn { ROWNUM = , EMPID, EMPNAME, SEX, SALARY, ADRRESS, PHONE, TEL, PO ...
- easyui的datagrid改变单元格颜色
另一种方法:https://www.cnblogs.com/raitorei/p/10395233.html easyui的datagrid改变整行颜色:https://www.cnblogs.com ...
随机推荐
- PAT L2-005 集合相似度(模拟集合set)
给定两个整数集合,它们的相似度定义为:Nc/Nt*100%.其中Nc是两个集合都有的不相等整数的个数,Nt是两个集合一共有的不相等整数的个数.你的任务就是计算任意一对给定集合的相似度. 输入格式: 输 ...
- 跳跃游戏 12 · Jump Game 12
跳跃游戏 1 [抄题]: [思维问题]: [一句话思路]: [输入量]:空: 正常情况:特大:特小:程序里处理到的特殊情况:异常情况(不合法不合理的输入): [画图]: [一刷]: 由于要用itera ...
- sql优化常用命令总结
1.显示执行计划的详细步骤 SET SHOWPLAN_ALL ON; SET SHOWPLAN_ALL OFF; 2. 显示执行语句的IO成本,时间成本 SET STATISTICS IO ON SE ...
- mysql contact_ws函数 字符串被截断问题
contact函数默认有字符串长度限制,解决方法:SET group_concat_max_len = 20000这个参数设置一下就好了
- Response.Redirect原理图解
- 局部方法$("html").load()和全局方法$.get()、$.post()
一..load() .load()方法可以参数三个参数:url(必须,请求 html 文件的 url 地址,参数类型为 String).data(可选,发送的 key/value 数据,参数类型为 O ...
- Largest product from 3 integers
https://github.com/Premiumlab/Python-for-Algorithms--Data-Structures--and-Interviews/blob/master/Moc ...
- 2018.09.01 poj2689 Prime Distance(埃式筛法)
传送门 一道挺有趣的. 第一眼以为每个数都用miller_rabin判一次,但感觉会被卡时间啊. 继续分析发现可以晒出sqrt(r)中的所有素数,然后用类似埃式筛法的方法晒出[l,r]" r ...
- C++之类和对象的使用(二)
析构函数 析构函数的作用并不是删除对象,而是在撤销对象占用的内存之前完成一系列清理工作,使这部分内存可以被程序分配给新对象使用.对象生命周期结束,程序就自动执行析构函数来完成这些工作. 析构函数是一种 ...
- 状态机中的RAM注意的问题--减少扇出的办法
可能我不会抓紧时间,所以做事老是很慢.最近在整维特比译码过程深感自己有这样的毛病. 每天会有一点进展,但是却是一天的时间,感觉别人都做起事情来很快.可能这个东西有点难,做 不做得出来都不要紧,但我的想 ...