基于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 ...
随机推荐
- day11:vcp考试
Q201. Which two options are available in the Virtual Machine Component Protection (VMCP) setting Res ...
- 数字三角形 · Triangle
从上到下用DP. [抄题]: 给定一个数字三角形,找到从顶部到底部的最小路径和.每一步可以移动到下面一行的相邻数字上. 比如,给出下列数字三角形: [ [2], [3,4], [6,5,7], [4, ...
- Struts2的拦截器技术
1. 拦截器的概述 * 拦截器就是AOP(Aspect-Oriented Programming,面向切面)的一种实现.(AOP是指用于在某个方法或字段被访问之前,进行拦截然后在之前或之后加入某些操作 ...
- 【原创】有关Silverlight中 "Silverlight提示4004错误" 的解决方案及思路。
今天下午再改一个页面xaml时没注意一个细节导致了这个错误,整整搞了1个小时.在这给大家参考参考. 出错原因: 总结:其实silverlight已经提示了 出错的细节信息了,没必要因为silverli ...
- 解决 Ubuntu 下 sudo 命令执行速度慢的问题
1.首先如果当用登录的用户名不在"/etc/sudoers"文件中,是不能执行sudo命令的.可以用root身份手动修该文件,把当前登录用户名加入该文件中. 2.用"ho ...
- 执行程序---system
头文件:#include<stdlib.h> 函数原型:int system(const char *command) 参数说明:command被执行的命令,字符串格式 返回值:成功则返回 ...
- chrome审查元素功能,web开发强大帮手
怎样打开Chrome的开发者工具? 你可以直接在页面上点击右键,然后选择审查元素: 或者在Chrome的工具中找到: 或者,你直接记住这个快捷方式: Ctrl+Shift+I (或者Ctrl+Shif ...
- eclipse代码自动提示,eclipse设置代码自动提示
eclipse代码自动提示,eclipse设置代码自动提示 eclipse是很多JAVA开发者基本上都用的工具,用它可以很方便的开发JAVA代码,当编写JAVA代码时,大部分人都是按组合键[Alt+/ ...
- java socket 之UDP编程
一.概念 在TCP的所有操作中都必须建立可靠的连接,这样一来肯定会浪费大量的系统性能,为了减少这种开销,在网络中又提供了另外的一种传输协议——UDP,不可靠的连接(这种协议在各种聊天工具中被广泛使用) ...
- Map的常用操作
public static void main(String[] args) { Map<String, String> map = new HashMap<>(); map. ...