`
renjie120
  • 浏览: 238800 次
  • 性别: Icon_minigender_1
  • 来自: 上海
博客专栏
D11bba82-ec4a-3d31-a3c0-c51130c62f1c
Java应用集锦
浏览量:23110
社区版块
存档分类
最新评论

jquery写的合并单元格的一个方法

阅读更多

项目中经常使用的一个功能就是把排序之后的表格进行单元格的合并,一般是列的合并.

之前使用的方法是在后台进行html拼串,结果造成后台及其复杂,可维护性很差.

 

自己的想法就是在画完了表格之后再修改表格的结果,添加rowspan属性达到合并单元格的目的.

 

思路: 假如表格列数据依次是A,A,A,B,B,B,C,C,C 显示表格完之后,进行逐行进行查找得到这样的一个数组[3,3,3] ,表示重复的单元格的次数,然后在进行一次循环,再根据这里的数组里面的数字进行处理,将第一个遇到的单元格设置rowspan属性,剩余的重复的单元格remove掉...有点小小复杂的算法. 

 

用jquery写完之后,到网上搜了一下,才发现有普通的js的版本的,看了一下,思路基本差不多.这里把我写的jquery的版本代码粘贴出来,附件有两个版本的网页.

/**
  * willcheck:要进行处理的表格对象(或者行的集合即可)
  * colnum:要进行合并单元格的列
  */
function coltogather(willcheck,colnum){ 
	var alltext = [],togotherNum = [],oldnum = [],id=1,lasttext=null,rmflag=1; 
	//逐列的数据进行扫描,得到里面的不重复的数据,以及各个数据的数目,然后将依据此结果进行设置rowspan属性
	willcheck.each(function(){
	      var _rmnum = this.getAttribute('rmnum');
		  if(!_rmnum)_rmnum=0;
	      var trdom= jQuery('td:eq('+(colnum-_rmnum)+')',this)
		  var text = jQuery(trdom).text();  
		  //如果上一行记录文本为空,说明是第一行
		  if(lasttext==null) {
			   lasttext = text;
		  }else {
			  //如果当前行和上一行记录一样,说明要进行合并,合并的单元格数目就加1
			  if(lasttext!=text){  
				   togotherNum.push(id);
				   lasttext = text;
				   id = 1;
			  } else{
			      id++;
			  }
		  }
		  
	 });   
	 togotherNum.push(id); 
	 //复制allnum数组中的数据到oldnum数组
	 jQuery.each(togotherNum, function(i, n){
         oldnum[i] =n;
     }); 
     var index = 0,len = togotherNum.length;
	 //逐行进行处理,设置指定列的rowspan属性,以及将要合并的单元格remove!
	 willcheck.each(function() {
				// 得到一个属性表示该行已经被移除了几个td
				var _rmnum = this.getAttribute('rmnum');
				if (!_rmnum)
					_rmnum = 0;
				var tddom = jQuery('td:eq(' + (colnum - _rmnum) + ')', this)
				if (togotherNum[index] == oldnum[index]) {
					tddom.attr('rowSpan', togotherNum[index]);
					if(togotherNum[index]>1)
					  togotherNum[index] = togotherNum[index] - 1;
					 else
					   index++;
				} else { 
					if (togotherNum[index] == 0) {
						index++;
					    tddom.attr('rowSpan', togotherNum[index]);
					} else {
				    	tddom.remove(); 
						if(--togotherNum[index]==0){
							index++;
						}
					}
					// 移除了td之后,要在tr里面添加一个属性标示已经移除的td的数目
					if (_rmnum == 0) {
						jQuery(this).attr('rmnum', 1);
					} else {
						jQuery(this).attr('rmnum', 1 + _rmnum * 1);
					}
				}
			});   
	 //清空数组
	 alltext = null;
	 togotherNum = null;
	 oldnum = null; 
}

 全部的可执行网页见附件.

 

感觉没有必要总是使用jquery做这些事情,因为可以看到普通的js一样可以处理很多的事情,用jquery的话有点杀鸡用牛刀了,不过jquery确实很方便.

分享到:
评论
15 楼 NeverGiveUpToChange 2013-07-10  
非常非常感谢!!!!
14 楼 interjc 2013-05-14  
renjie120 写道
interjc 写道
对dom操作过多会有性能问题,我的做法一般是对后台传来的json对象进行直接拼合字符串统一输出,这样性能会好很多。

恩 具体问题具体分析.我们的表格数据很大的,以前就是用的你的类似的方法在后台直接拼html显示在前台,结果后台代码乱七八糟.
现在的这样js处理,在显示一页1000条的时候略有影响可以看出白页的效果,其余不会出现明显的停顿.

不是后台拼,而是用js拼好字符串后再输出
13 楼 zhujiangtaobl0505 2013-05-14  
谢谢!!!,帮我大忙了!
12 楼 renjie120 2011-10-28  
Jonefy 写道
下载文件功能还有问题!
孙臻轶              博时基金 A010 5138747387.68 5227092648.81 2
                         A010 5138747387.68 5227092648.81 16
                         A010 5138747387.68 5227092648.81 2
      2010-10-21 测试本机 A010 5138747387.68 5227092648.81 2
                         A010 5138747387.68 5227092648.81 16
                         A010 5138747387.68 5227092648.81 2
                 信托基金 A010 5138747387.68 5227092648.81 2
                         A010 5138747387.68 5227092648.81 16
                         A010 5138747387.68 5227092648.81 2

严娅 2010-10-21 博时基金 A002 3013162363.57 0 1
    2010-10-21 博时基金 A002 3013162363.57 0 8
                       A002 3013162363.57 0 1
               测试本机 A002 3013162363.57 0 1
                       A002 3013162363.57 0 8
                       A002 3013162363.57 0 1
               信托基金 A002 3013162363.57 0 1
                       A002 3013162363.57 0 8
                       A002 3013162363.57 0 1


我这里合并的用途只在显示页面做的操作,而下载的话我不知道你是怎么实现的,是不是下载的jsp文件然后设置头信息为excel类型.如果是这样可能没有问题(我没有试验过)..如果有问题,要自己解决了.
11 楼 Jonefy 2011-10-27  
下载文件功能还有问题!
孙臻轶              博时基金 A010 5138747387.68 5227092648.81 2
                         A010 5138747387.68 5227092648.81 16
                         A010 5138747387.68 5227092648.81 2
      2010-10-21 测试本机 A010 5138747387.68 5227092648.81 2
                         A010 5138747387.68 5227092648.81 16
                         A010 5138747387.68 5227092648.81 2
                 信托基金 A010 5138747387.68 5227092648.81 2
                         A010 5138747387.68 5227092648.81 16
                         A010 5138747387.68 5227092648.81 2

严娅 2010-10-21 博时基金 A002 3013162363.57 0 1
    2010-10-21 博时基金 A002 3013162363.57 0 8
                       A002 3013162363.57 0 1
               测试本机 A002 3013162363.57 0 1
                       A002 3013162363.57 0 8
                       A002 3013162363.57 0 1
               信托基金 A002 3013162363.57 0 1
                       A002 3013162363.57 0 8
                       A002 3013162363.57 0 1

10 楼 renjie120 2011-01-24  
yiyi_2 写道
试了下,点击合并按钮后没反应啊

不用点击,已经是合并了单元格了。呵呵
9 楼 yiyi_2 2011-01-24  
试了下,点击合并按钮后没反应啊
8 楼 flamesea 2011-01-24  
renjie120 写道

但是你这样的话,要改动后台代码,对吧?而只用前台js处理的话,就不用改动后台的java代码.前台数据量多了,可能会有性能的影响.

如果只是为了避免改,后台一样可以做成可配置形式。至于数据量大的问题,数据量大,前台PC的压力肯定比后台服务器来的大,况且我这样做,实际上是压缩了数据量,因为合并了一些重复的数据。另外,每页显示1000条数据,个人认为对用户是非常不友好的,所以我做表格显示的时候基本不会这样做。

flashing 写道
不错,.另外我觉得是还是像lz这样在js里面处理比较好,在服务器端合并性能更差,现在浏览器js引擎的性能已经不是当年了。
另外把计算的事情扔给各个客户端,在有一定并发压力的时候其实是更明智的办法。

你这个想法我是赞同的,但我做的是企业内部的应用,办公用PC难免良莠不齐,而且越是一线的业务员,所用的机器往往越差,去年因为这个栽过跟头,所以印象深刻。不过还是一句话,具体问题具体分析吧。

7 楼 flashing 2011-01-23  
不错,.另外我觉得是还是像lz这样在js里面处理比较好,在服务器端合并性能更差,现在浏览器js引擎的性能已经不是当年了。
另外把计算的事情扔给各个客户端,在有一定并发压力的时候其实是更明智的办法。
6 楼 renjie120 2011-01-22  
lobbychmd 写道
写的太不 jquery 了。
手痒写了一段

<script type="text/javascript">

$.fn.merge = function () {  
  return this.each(function(){
   for(var i= $(this).find('tr:first td').size() -1; i>=0; i--){
     var s = null;
     var prevTd = null;
     $(this).find('tr').each(function(){ 
       var td = $(this).find('td').eq(i);
       var s1= td.text() ;
       if (s1 == s) {
         td.remove();
         prevTd.attr('rowspan', prevTd.attr('rowspan')? parseInt(prevTd.attr('rowspan')) + 1:2);
       }
       else {
         s = s1;
         prevTd = td;
       }
     });
   }
  });
}

$(document).ready(function(){
  $('button').click(function(){
    $('table').merge();
  });
});
</script>

谢谢指点!学习了!
5 楼 lobbychmd 2011-01-22  
写的太不 jquery 了。
手痒写了一段

<script type="text/javascript">

$.fn.merge = function () {  
  return this.each(function(){
   for(var i= $(this).find('tr:first td').size() -1; i>=0; i--){
     var s = null;
     var prevTd = null;
     $(this).find('tr').each(function(){ 
       var td = $(this).find('td').eq(i);
       var s1= td.text() ;
       if (s1 == s) {
         td.remove();
         prevTd.attr('rowspan', prevTd.attr('rowspan')? parseInt(prevTd.attr('rowspan')) + 1:2);
       }
       else {
         s = s1;
         prevTd = td;
       }
     });
   }
  });
}

$(document).ready(function(){
  $('button').click(function(){
    $('table').merge();
  });
});
</script>
4 楼 renjie120 2011-01-22  
interjc 写道
对dom操作过多会有性能问题,我的做法一般是对后台传来的json对象进行直接拼合字符串统一输出,这样性能会好很多。

恩 具体问题具体分析.我们的表格数据很大的,以前就是用的你的类似的方法在后台直接拼html显示在前台,结果后台代码乱七八糟.
现在的这样js处理,在显示一页1000条的时候略有影响可以看出白页的效果,其余不会出现明显的停顿.
3 楼 interjc 2011-01-22  
对dom操作过多会有性能问题,我的做法一般是对后台传来的json对象进行直接拼合字符串统一输出,这样性能会好很多。
2 楼 renjie120 2011-01-20  
flamesea 写道
和我做类似功能的思路很不一样
我倾向于在服务器端就做好一定的合并,然后页面上直接遍历构建

例如,原始的变量是这样
[
{ var1: "aa", var2: "b1", var3: "c1"},
{ var1: "aa", var2: "b2", var3: "c2"},
{ var1: "xx", var2: "yy", var3: "zz"},
……
]
我一般先在服务器端转换为这样的形式
[
{ var1: "aa", sub: [{var2: "b1", var3: "c1"}, {var2: "b2", var3: "c2"}]},
{ var1: "xx", sub: [{var2: "yy", var3: "zz"}],
……
]

然后按照数据,一次性生成合并行列的表格
可以减少对dom对象的操作,个人认为好些

但是你这样的话,要改动后台代码,对吧?而只用前台js处理的话,就不用改动后台的java代码.前台数据量多了,可能会有性能的影响.
1 楼 flamesea 2011-01-20  
和我做类似功能的思路很不一样
我倾向于在服务器端就做好一定的合并,然后页面上直接遍历构建

例如,原始的变量是这样
[
{ var1: "aa", var2: "b1", var3: "c1"},
{ var1: "aa", var2: "b2", var3: "c2"},
{ var1: "xx", var2: "yy", var3: "zz"},
……
]
我一般先在服务器端转换为这样的形式
[
{ var1: "aa", sub: [{var2: "b1", var3: "c1"}, {var2: "b2", var3: "c2"}]},
{ var1: "xx", sub: [{var2: "yy", var3: "zz"}],
……
]

然后按照数据,一次性生成合并行列的表格
可以减少对dom对象的操作,个人认为好些

相关推荐

    jquery datatable 单元格合并

    通过Datatables的`drawCallback`或`initComplete`事件,在表格渲染完成后合并单元格。遍历预处理得到的合并信息,使用DOM操作修改表格结构。 ```javascript $('#example').DataTable({ // ...其他配置... ...

    jQuery实现合并单元格功能

    在压缩包中的"jquery合并单元格"文件可能包含了具体的示例代码或者更复杂的合并功能实现。通过查看和学习这些示例,你可以进一步理解和掌握如何使用jQuery实现单元格合并。同时,为了保证代码的可维护性和性能,记得...

    jQuery合并单元格

    "jQuery合并单元格"这个主题涉及到在HTML表格中合并单元格的技术,这对于创建复杂的表格布局或呈现数据时非常有用。下面我们将深入探讨如何使用jQuery和JavaScript实现单元格的合并。 首先,我们需要理解HTML表格的...

    jquery 动态合并单元格的实现方法

    ////table中指定行第N列合并单元格(合并后会多出一列,删除N+1单元格即可) var tds = $("#dgList .TableHeader1").find('td'); tds[6].setAttribute("colSpan", "2"); 还可以写成:tds[6].attr("rowSpan", 2);

    jqgrid合并单元格,合并行、合并列

    jqgrid合并单元格 .jqgrid { width: 80%; margin: 0 auto; } /* 这个代码是解决表头有一点点错位的问题 */ .ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-...

    合并单元格例子(jquery)

    下面是一个简单的例子,展示了如何使用jQuery合并单元格: ```html &lt;!DOCTYPE html&gt; &lt;script src="https://code.jquery.com/jquery-3.6.0.min.js"&gt;&lt;/script&gt; &lt;td&gt;Header 1 &lt;td&gt;Header 2 &lt;td&gt;Header 3 ...

    jquery超好用的合并单元格

    jquery封装超好用的合并单元格方法,很好用,欢迎大家下载使用。

    table合并单元格的多种方法

    在表格(Table)设计中,有时我们需要合并单元格来达到特定的展示效果,例如创建标题行或列,或者为了美观和布局对齐。在HTML、CSS以及JavaScript中,都有多种方式可以实现单元格的合并。这里我们将详细探讨六种合并...

    JQuery表格合并单元格

    合并单元格 JQuery源码 MergeCells 加入JQuery库和MergeCells即可. EP: $('#table').MergeCells({cols:'1,2,3'}) 合并第2,3,4列.

    jquery.table.rowspan.js 表格自动合并单元格插件

    `jQuery.table.rowspan.js`插件的核心思想是遍历表格中的每一行,根据设定的规则(如相同的值或特定条件)来检测是否需要合并单元格,并动态设置`rowspan`属性。这样,原本需要在服务器端进行的复杂逻辑计算,被转移...

    将HtmlTable 导出为Execl文件,支持合并单元格、合并行,无需Office支持

    本项目提供了一个解决方案,它支持合并单元格和合并行,无需依赖Microsoft Office,这对于那些无法安装Office环境或者希望在服务器端执行此操作的用户来说,具有很高的实用价值。 首先,我们要理解HTML表格...

    easyuiPoi导出Excel工具类封装(支持合并单元格)

    3. 合并单元格:如果需要合并单元格,可以调用`Sheet`对象的`mergeCells()`方法,指定起始和结束的单元格坐标。 4. 保存和导出:完成数据填充和合并后,调用`Workbook`对象的`write()`方法将工作簿写入到输出流,...

    bootstrap-table导出合并单元格

    在描述中提到的"bootstrap-table导出合并单元格"是该插件的一个高级特性,允许用户在导出表格时,将具有相同内容的单元格进行合并,以提高数据的可读性和美观性。 1. **Bootstrap Table简介** Bootstrap Table是一...

    jquery table rowspan 表格单元格合并Demo.zip

    在网页开发中,jQuery 是一个广泛使用的 JavaScript 库,它极大地简化了 JavaScript 的操作,包括对 HTML 文档的处理、事件处理、动画效果以及Ajax交互。在这个“jquery table rowspan 表格单元格合并Demo.zip”中,...

    动态向下合并单元格

    向下合并单元格是指在表格中,如果连续几行具有相同的特定列值,那么这些行的该列会被合并成一个单元格,其内容是这些行共享的值,而下方的行则被隐藏。这种操作有助于减少重复信息,使得表格看起来更有序,提升...

    JSP Table 单元格合并

    每次遍历时都会更新计数器 `count`,用于记录合并单元格所占据的行数。 ```javascript count++; ``` #### 三、JSP 示例代码解析 在 JSP 文件中,使用 `&lt;s:iterator&gt;` 标签来迭代列表,并为每个元素生成一个表格行...

    Jquery合并单元格--网摘

    在网页开发中,jQuery 是一个非常流行的 JavaScript 库,它简化了 DOM 操作、事件处理以及动画效果。本文将探讨如何使用 jQuery 来合并表格中相同文本的相邻单元格,这是在展示数据时提高可读性和美观度的一种常见...

    jqgrid合并单元格.rar

    本压缩包“jqgrid合并单元格.rar”提供了一个解决方案,用于在jqGrid中实现单元格的合并,包括行合并和列合并,使得数据展示更为清晰、有组织。 首先,jqGrid的单元格合并功能主要通过设置表格的colModel属性和grid...

    动态合并单元格JQUERY.txt

    合并单元格主要是指将具有相同内容的相邻单元格(通常为垂直方向)合并为一个单元格,同时设置`rowspan`属性来表示合并后的单元格跨越的行数。 #### 代码分析 给定的代码片段展示了如何使用jQuery动态地合并表格中...

Global site tag (gtag.js) - Google Analytics