合并表格第一列

最近老是遇见第一列是地市,第二列是区县。说一堆区县对应一个地市看起来不太好看,要把第一列的地市合并在一起。故写了个小小的Demo,留待以后复用。

先看效果图,表一为原数据效果,表二为合并第一列后的数据效果:

核心代码为一小段js:

<script type="text/javascript">
	window.onload = function () {
      mergeTable("tt2",0,1);
  };
  /* tableId:表格的ID,mergeColIndex:需要合并的列序号,beginRowIndex:合并开始的行序号 */
  function mergeTable(tableId,mergeColIndex,beginRowIndex){
  	var table = document.getElementById(tableId);
  	if(table!=null){
  		var totalRows = table.rows.length;
  		for(var i=beginRowIndex;i<totalRows;i++){
  			var rowSpan = 1;
  			var cell = table.rows[i].cells[mergeColIndex].innerHTML;
  			for(var j=i+1;j<totalRows;j++){
  				if(table.rows[j].cells[mergeColIndex].innerHTML==cell){
  					rowSpan++;
  					table.rows[i].cells[mergeColIndex].rowSpan = rowSpan;//设置rowSpan
  					table.rows[j].cells[mergeColIndex].style.display = "none";//当前行被合并了,所以这里设置为none
  				}else{
  					break;
  				}
  			}
  			i = i+rowSpan-1;//跳到最后一个相同的行,然后再+1就是另一个不相同的行啦
  		}
  	}
  }
</script>

下面是我的静态html代码,可以直接复制下来,放到文本文件中,然后保存为.html文件,就可以直接打开看效果啦。

<!DOCTYPE HTML>
<html>
<head>
	<title>mergeTable</title>
	<meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
	<meta name="author" content="yunsyz"/>
	<meta name="revised" content="2015-01-22" sechema="YYYY-MM-DD"/>
	<meta http-equiv="Refresh" content="60;url=http://blog.csdn.net/yunsyz/article/details/43016663"/>
	<style type="text/css">
		.mergeTable{width:100%;border:1px solid;border-collapse:collapse;table-layout:fixed;}
		.mergeTable th,.mergeTable td{border:1px solid;text-align:center;}
	</style>
</head>
<body>
<div>
	<h4>表一</h4>
	<table id="tt1" class="mergeTable">
		<thead>
			<tr>
				<th>地市</th>
				<th>区县</th>
				<th>本月值</th>
				<th>上月值</th>
				<th>环比</th>
			</tr>
		</thead>
		<tbody>
			<tr>
				<td>武汉</td>
				<td>汉口</td>
				<td>45.34</td>
				<td>65.78</td>
				<td>22.03%</td>
			</tr>
			<tr>
				<td>武汉</td>
				<td>武昌</td>
				<td>55.34</td>
				<td>75.78</td>
				<td>32.03%</td>
			</tr>
			<tr>
				<td>武汉</td>
				<td>汉阳</td>
				<td>65.34</td>
				<td>85.78</td>
				<td>42.03%</td>
			</tr>
			<tr>
				<td>上海</td>
				<td>浦东</td>
				<td>56.11</td>
				<td>48.87</td>
				<td>0.34%</td>
			</tr>
			<tr>
				<td>上海</td>
				<td>城区</td>
				<td>65.11</td>
				<td>43.87</td>
				<td>1.34%</td>
			</tr>
			<tr>
				<td>重庆</td>
				<td>城区</td>
				<td>54.00</td>
				<td>32.90</td>
				<td>10.00%</td>
			</tr>
			<tr>
				<td>北京</td>
				<td>二环</td>
				<td>73.77</td>
				<td>21.34</td>
				<td>42.46%</td>
			</tr>
			<tr>
				<td>北京</td>
				<td>三环</td>
				<td>55.77</td>
				<td>17.34</td>
				<td>165.46%</td>
			</tr>
		</tbody>
	</table>
	<h4>表二</h4>
	<table id="tt2" class="mergeTable">
		<thead>
			<tr>
				<th>地市</th>
				<th>区县</th>
				<th>本月值</th>
				<th>上月值</th>
				<th>环比</th>
			</tr>
		</thead>
		<tbody>
			<tr>
				<td>武汉</td>
				<td>汉口</td>
				<td>45.34</td>
				<td>65.78</td>
				<td>22.03%</td>
			</tr>
			<tr>
				<td>武汉</td>
				<td>武昌</td>
				<td>55.34</td>
				<td>75.78</td>
				<td>32.03%</td>
			</tr>
			<tr>
				<td>武汉</td>
				<td>汉阳</td>
				<td>65.34</td>
				<td>85.78</td>
				<td>42.03%</td>
			</tr>
			<tr>
				<td>上海</td>
				<td>浦东</td>
				<td>56.11</td>
				<td>48.87</td>
				<td>0.34%</td>
			</tr>
			<tr>
				<td>上海</td>
				<td>城区</td>
				<td>65.11</td>
				<td>43.87</td>
				<td>1.34%</td>
			</tr>
			<tr>
				<td>重庆</td>
				<td>城区</td>
				<td>54.00</td>
				<td>32.90</td>
				<td>10.00%</td>
			</tr>
			<tr>
				<td>北京</td>
				<td>二环</td>
				<td>73.77</td>
				<td>21.34</td>
				<td>42.46%</td>
			</tr>
			<tr>
				<td>北京</td>
				<td>三环</td>
				<td>55.77</td>
				<td>17.34</td>
				<td>165.46%</td>
			</tr>
		</tbody>
	</table>
</div>
<script type="text/javascript">
	window.onload = function () {
      mergeTable("tt2",0,1);
  };
  /* tableId:表格的ID,mergeColIndex:需要合并的列序号,beginRowIndex:合并开始的行序号 */
  function mergeTable(tableId,mergeColIndex,beginRowIndex){
  	var table = document.getElementById(tableId);
  	if(table!=null){
  		var totalRows = table.rows.length;
  		for(var i=beginRowIndex;i<totalRows;i++){
  			var rowSpan = 1;
  			var cell = table.rows[i].cells[mergeColIndex].innerHTML;
  			for(var j=i+1;j<totalRows;j++){
  				if(table.rows[j].cells[mergeColIndex].innerHTML==cell){
  					rowSpan++;
  					table.rows[i].cells[mergeColIndex].rowSpan = rowSpan;//设置rowSpan
  					table.rows[j].cells[mergeColIndex].style.display = "none";//当前行被合并了,所以这里设置为none
  				}else{
  					break;
  				}
  			}
  			i = i+rowSpan-1;//跳到最后一个相同的行,然后再+1就是另一个不相同的行啦
  		}
  	}
  }
</script>
</body>
</html> 
时间: 2024-08-03 05:40:55

合并表格第一列的相关文章

word中给表格第一列加序号

插入表格后,选中第一列,选编号 然后定义新的编号格式

合并表格

<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <title>合并表格</title> <script> /////////////////////////////////////////////// //功能:合并表格 //参数:tb-需要合并的表格ID //参数:colLen

使用jquery合并表格中相同文本的相邻单元格

一.效果 二.代码 <!DOCTYPE HTML> <html> <head> <title>Example</title> <meta charset="utf-8"/> <style></style> <script src="js/jquery-2.1.4.min.js"></script> </head> <body>

(原创) cocos2d-x 3.0+ lua 学习和工作(4) : 公共函数(6): 合并表格:table.merge

这里的函数主要用来做:合并表格.参考资料为quick_cocos. 星月倾心贡献~~~ --[[ -- 将 来源表格 中所有键及值复制到 目标表格 对象中,如果存在同名键,则覆盖其值 -- example local tDest = { a = 1, b = 2 } local tSrc = { c = 3, d = 4 } table.merge( tDest, tSrc ) -- tDest = { a = 1, b = 2, c = 3, d = 4 } -- @param tDest 目

JS自动合并表格

1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 2 <html xmlns="http://www.w3.org/1999/xhtml"> 3 <head> 4 <meta http-equiv="

jQuery取得循环列表的第一列值

有如下的表格: <table class="list_tab" id="personalDetail"> <tr class="head"> <th>体检编号</th> <th>姓名</th> <th>性别</th> <th>年龄</th> <th>个人状态</th> <th>单位名称<

WordPress后台的文章、分类,媒体,页面,评论,链接等所有信息中显示ID并将ID设置为第一列

WordPress后台默认是不显示文章.分类等信息ID的,查看起来非常不方便,不知道Wp团队出于什么原因默认不显示这个但可以使用Simply Show IDs插件来实现 不使用插件,其他网友的实现: <?php /** *为WordPress后台的文章.分类等显示ID From wpdaxue.com * ID默认添加到列的后面 * http://www.wpdaxue.com/simply-show-ids.html * htl add 2015-01-16 */ //添加一个新的列 ID f

CSS表格固定列宽

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-

VC CListCtrl 第一列列宽自适应

原文链接: http://www.cnblogs.com/sephil/archive/2011/04/03/2004384.html 今天用VC写工具的时候用到CListView,并且ListCtrl的第一列需要自动拉伸,以占满空白区域 Delphi做这个设置是很容易的,只要将Column的AutoSize设置为True就可以了 不过VC/SDK的AutoSize其实是根据Item的文本长度来自动设置Column Width,跟我的要求不符,只好自己实现了 其实很简单,就是觉得麻烦... vo