Js 合并 table 行 的实现方法
Js 合并 table 行 的实现方法
需求如下:
某公司的员工档案,如下, 经理看员工的信息不是很清晰:
|
姓名 |
所在学校 |
毕业时间 |
|
张三 |
小学 |
2000 |
|
张三 |
中学 |
2006 |
|
张三 |
大学 |
2010 |
|
李四 |
小学 |
2000 |
|
李四 |
中学 |
2006 |
|
王五 |
小学 |
2006 |
所以要求要求姓名一列如果发现挨着的名字相同的话,将其合并为一行,如下图所示:
|
姓名 |
所在学校 |
毕业时间 |
|
张三 |
小学 |
2000 |
|
中学 |
2006 |
|
|
大学 |
2010 |
|
|
李四 |
小学 |
2000 |
|
中学 |
2006 |
|
|
王五 |
小学 |
2006 |
这样看起来是不是很清晰...
解决思路
1. 首先我想封装一个方法,这个方法应该是:
a) 操作哪一个table
b) 这个table的列(要合并的列)
c) 从第几行开始合并(如:表头行不参与合并),
d) 结束到第几行(如:分页行不参与合并)
2. 具体内部方法的实现
a) 我想先用一个集合来存储相同的名称的个数(如:[3,2,1] 也就是 [张三的个数,李四的个数,王五的个数])
b) 然后循环table的行数,如果 数组中的数大于1,我要将大于1的td给删掉。
3. 在循环的同时添加条件。
以上就是我要解决这个问题的主要思路.那大家就先看看我的具体代码吧:
- /**
- data格式{'table':$('tableId'),'columnId':'0','startRowNumber':'1','endRowNumber':}
- */
- function initRowsPan(data) {
- //判断table是否存在
- if(!data.table)
- {
- return;
- }
- //判断是否存在操作的列编号
- if(!data.columnId||data.columnId<0)
- {
- return;
- }
- //记录开始的行号,如果为空,则默认从第0行开始
- var tStartNumber=data.startRowNumber;
- if(!tStartNumber||tStartNumber<0)
- {
- tStartNumber=0;
- }
- //记录table的所有hang集合
- var tableRows = data.table.rows;
- //记录结束的行号,如果为空,则默认为table的行号
- var tEndNumber=data.endRowNumber;
- if(!tEndNumber||tEndNumber<=0)
- {
- tEndNumber=tableRows.length;
- }
- else
- {
- //给传来的编号加1,因为表格的行编号是从0开始.
- tEndNumber+=1;
- }
- //得到相同内容的行数的集合
- var totalcount = new Array();
- //临时变量,循环记录表格中td的内容,用来判断td中的value是否发生修改
- var tTdValue = "";
- //临时变量,再循环时,如果td的值相同,那么变量加1, 否则将临时变量压入集合中
- var tRowsCount = 1;
- //存储table 的所有行数
- for ( var i = data.startRowNumber; i < tEndNumber; i++)
- {
- //首先拿出来td的值
- var tTdInner=tableRows[i].cells[data.columnId].innerHTML.trim();
- //如果是第一次走循环,直接continue;
- if (i == data.startRowNumber)
- {
- tTdValue = tTdInner;
- continue;
- }
- //如果当前拿出来的值和出处的值相同,那么将临时数量加1
- if (tTdValue == tTdInner)
- {
- tRowsCount++;
- }
- else
- {
- //否则添加到集合里面
- totalcount.push(tRowsCount);
- //并且将当前的td中的value赋给变量
- tTdValue = tTdInner;
- //数量清为1
- tRowsCount = 1;
- }
- //判断是否是循环的最后一次,如果是最后一次那个直接将当前的数量存储到集合里面
- if (i == tEndNumber -1)
- {
- totalcount.push(tRowsCount);
- }
- }
- //临时变量,再循环中判断是否和数组中的一项值相同
- var tNum = 0;
- //注意这个循环是倒着来的
- for (var i = tEndNumber - 1; i >= data.startRowNumber; i--)
- {
- //临时变量,存储td
- var tTd=tableRows[i].cells[data.columnId];
- tNum++;
- //如果发现tNum和数组中最后一个值相同,那么就可以断定相同的td已经结束[只是其中一个]
- if (tNum == totalcount[totalcount.length - 1])
- {
- //给当前td添加rowSpan属性
- tTd.setAttribute("rowSpan",totalcount[totalcount.length - 1]);
- //将数组的最后一个元素弹出
- totalcount.pop();
- tNum = 0;
- }
- else
- {
- //删除当前td
- tableRows[i].removeChild(tTd);
- }
- }
- }
在onload事件里面调用函数
总结
其实每一个问题都会有很多的解决办法,这个是我在前台实现,其实大家也还可以在页面里面添加判断,来输出效果. 我们在做的时候多想想,多动动脑子,怎样才能使我们做事情更方便一些,会更节省时间,每次多积累,多总结,这样我们就会提高很多…
这是晚辈的第三篇技术文章,文章写的不是很好,希望各位前辈多多指教,
Js 合并 table 行 的实现方法的更多相关文章
- JS合并两个数组的方法
JS合并两个数组的方法 我们在项目过程中,有时候会遇到需要将两个数组合并成为一个的情况.比如: var a = [1,2,3]; var b = [4,5,6]; 有两个数组a.b,需求是将两个数组合 ...
- 使用js合并table中的单元格
用primefaces做的报表,领导要求合并相同内容的单元格,但是primefaces没有找到可以合并单元格的组件,想来想去,只有页面加载后用js合并了. http://blog.csdn.net/d ...
- SQL中合并多行记录的方法总汇
-- =============================================================================-- Title: 在SQL中分类合并数 ...
- JS合并数组的几种方法及优劣比较
本文属于JavaScript的基础技能. 我们将学习结合/合并两个JS数组的各种常用方法,并比较各种方法的优缺点. 我们先来看看具体的场景: var q = [ 5, 5, 1, 9, 9, 6, 4 ...
- [Js/Jquery]table行转列
摘要 在使用ews调用exhange的收件箱的并在h5页面显示邮件详情的时候,因为返回的每封邮件的内容都是htmlbody,没有textbody.每封邮件又没什么规律,用正则表达式来匹配内容并不合适, ...
- js合并table指定列
function MergeTableCell(tableId, startRow, endRow, col) { var tb = document.getElementById(tableId); ...
- 探讨JS合并两个数组的方法
我们在项目过程中,有时候会遇到需要将两个数组合并成为一个的情况. 比如: var a = [1,2,3]; var b = [4,5,6]; 有两个数组a.b,需求是将两个数组合并成一个.方法如下: ...
- 转:探讨JS合并两个数组的方法
我们在项目过程中,有时候会遇到需要将两个数组合并成为一个的情况. 比如: var a = [1,2,3]; var b = [4,5,6]; 有两个数组a.b,需求是将两个数组合并成一个.方法如下: ...
- [转] 探讨JS合并两个数组的方法
我们在项目过程中,有时候会遇到需要将两个数组合并成为一个的情况. 比如: 1 2 var a = [1,2,3]; var b = [4,5,6]; 有两个数组a.b,需求是将两个数组合并成一个.方法 ...
随机推荐
- 21天学通C++学习笔记(八):指针和引用
1. 简述 C++最大的优点之一是,既可以用它来编写不依赖于机器(主要是内存)的高级应用程序,又可以用它来编写与硬件紧密协作的应用程序. 事实上C++让您能够在字节和比特级调整应用程序的性能,而要编写 ...
- [HAOI2010]计数(组合数学)(数位DP)
原题题意也就是给的数的全排列小于原数的个数. 我们可以很容易的想到重复元素的排列个数的公式. 但是我们发现阶乘的话很快就会爆long long啊(如果您想写高精请便) 之后我就尝试质因数分解....但 ...
- 201621123012 《Java程序设计》第11周学习总结
作业11-多线程 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. 2. 书面作业 本次PTA作业题集多线程 1. 源代码阅读:多线程程序BounceThread ...
- C - Maximum of Maximums of Minimums(数学)
C - Maximum of Maximums of Minimums You are given an array a1, a2, ..., an consisting of n integers, ...
- 模糊查询中Like的使用
通配符: %. _ %:表示任意个或多个字符.可匹配任意类型和长度的字符 _:表示任意单个字符.匹配单个任意字符,它常用来限制表达式的字符长度语句:(可以代表一个中文字符) demo: //usern ...
- docker安装MySQL软件
1 搜索mysql镜像 $ sudo docker search mysql NAME DESCRIPTION STARS OFFICIAL AUTOMATED mysql MySQL is a wi ...
- 【洛谷 5002】专心OI - 找祖先 (树上计数)
专心OI - 找祖先 题目背景 \(Imakf\)是一个小蒟蒻,他最近刚学了\(LCA\),他在手机\(APP\)里看到一个游戏也叫做\(LCA\)就下载了下来. 题目描述 这个游戏会给出你一棵树,这 ...
- IT项目管理者常用的项目管理工具(国产VS进口)?
对于IT项目管理工具相信很多IT项目管理者都不陌生,因为它是我们每天都要接触的,但是在前期选择IT项目管理工具的时候往往是我们最头疼的时候,所以今天我就给大家带来几款常用的国内外IT项目管理工具介绍: ...
- squid的简单介绍
squid的简单介绍 squid的概念 squid是一种用来缓存Internet数据的软件.接受来自人们需要下载的目标(object)的请求并适当的处理这些请求.也就是说,如果一个人想下载一web界面 ...
- laravel5.8的使用
首先,确定电脑已经安装了composer.最好是全局安装 然后打开phpstorm的控制台: composer create-project --prefer-dist laravel/laravel ...