JQuery实现表格的相同单元格合并的三种方法

摘要:
通常需要合并表中的相同单元格。这里是您自己方法的总结。首先,在合并之前看一下效果图。合并后的效果图:代码:˂=“”){spanNum++;targetCell.attr;startCell.remove();}否则{spanNum=1;}startCell=targetCell;}}Functionmerge2(){//可以合并单元格。比较vartotalCols=$.find.find.length;vartotalRows=$.vind.leng;for{startCell=$.find.eq.find.eq;targetCell=$.find.eq(j-1).find.eeq;if(startCell.text())==targetCell.textFunctionmerge4(){//它与merge3方法类似,可以看出display:none和visibility之间的区别:hidden.vartotalCols=$.find.find.length;vartotalRows=$.find.leng;for{spanNum=1;startCell=$.ffind.eq.find.eq;for(varrow=totalRows-1

表格中相同单元格合并是经常需要用到的,针对自己做的方法做个小总结,先看一下合并前效果图,


合并后的效果图:

代码:

<!DOCTYPE html>
<html>
  <head>
    <title>merge.html</title>

    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="this is my page">
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
   
   
    <link rel="stylesheet" href="http://t.zoukankan.com/css/jquery-ui.css" />
    <script src="http://t.zoukankan.com/js/jquery.js"></script>
    <script src="http://t.zoukankan.com/js/jquery-ui.js"></script>
 
    <script type="text/javascript">
    function merge1(){         //可实现单元格,通过给 开始cell的比较
    var totalRow = $("#tbl").find("tr").length;
    var totalCol = $("#tbl").find("tr").eq(0).find("td").length;
       for(var col=totalCol-1;col>=1;col--){
    spanNum =1;
    startCell = $("#tbl").find("tr").eq(totalRow-1).find("td").eq(col);
    for(var row = totalRow-1;row>=1;row--){
    
targetCell = $("#tbl").find("tr").eq(row-1).find("td").eq(col);
  
if(startCell.text() == targetCell.text() && startCell.text()!=""){
   
spanNum++;
    targetCell.attr("rowSpan",spanNum);
   
startCell.remove();
   
}else{
   
spanNum =1;
   
}
    startCell = targetCell;
    }
    }      
         }
   
    function merge2() {     //可实现合并单元格,上下行来比较
var totalCols = $("#tbl").find("tr:eq(0)").find("td").length;
var totalRows = $("#tbl").find("tr").length;
for ( var i = totalCols-1; i >= 1; i--) {
for ( var j = totalRows-1; j >= 1; j--) {
startCell = $("#tbl").find("tr").eq(j).find("td").eq(i);
targetCell = $("#tbl").find("tr").eq(j - 1).find("td").eq(i);
if (startCell.text() == targetCell.text() && targetCell.text() != "") {
targetCell.attr("rowSpan", (startCell.attr("rowSpan")==undefined)?2:(eval(startCell.attr("rowSpan"))+1));
startCell.remove();
}
}
}
 }

/*先合并,使用style 的display:none将相同元素隐藏,然后再remove
*/
function merge3(){   
var totalCols = $("#tbl").find("tr:eq(0)").find("td").length;
var totalRows = $("#tbl").find("tr").length;
for(var col=totalCols-1;col>=1;col--){
    spanNum =1;
    startCell = $("#tbl").find("tr").eq(totalRows-1).find("td").eq(col);
    for(var row = totalRows-1;row>=1;row--){
      targetCell = $("#tbl").find("tr").eq(row-1).find("td").eq(col);
   
if(startCell.text() == targetCell.text() && startCell.text()!=""){
   
spanNum++;
   
targetCell.attr("rowSpan",spanNum);
   
startCell.attr("style","visibility:hidden");
    // startCell.attr("style","display:none");
  
}else{
  
spanNum =1;
   
}
   
startCell = targetCell;
   
}
    }
for(var j=totalCols-1;j>=1;j--){
  for(var i=totalRows-1;i>=1;i--){
     cell =  $("#tbl").find("tr").eq(i).find("td").eq(j);
     if(cell.attr("style")!=undefined){
          if(cell.attr("style")=="visibility:hidden"){
            cell.remove();
          }
     }
  }
}
}
   
     function merge4(){       //与merge3方法类似,目的是看一下 display:none与visibility:hidden的效果区别
var totalCols = $("#tbl").find("tr:eq(0)").find("td").length;
var totalRows = $("#tbl").find("tr").length;
for(var col=totalCols-1;col>=1;col--){
    spanNum =1;
    startCell = $("#tbl").find("tr").eq(totalRows-1).find("td").eq(col);
    for(var row = totalRows-1;row>=1;row--){
      targetCell = $("#tbl").find("tr").eq(row-1).find("td").eq(col);
   
if(startCell.text() == targetCell.text() && startCell.text()!=""){
   
spanNum++;
   
targetCell.attr("rowSpan",spanNum);
   
startCell.attr("style","display:none");
   
// startCell.attr("style","display:none");
   
}else{
   
spanNum =1;
   
}
   
startCell = targetCell;
   
}
    }
for(var j=totalCols-1;j>=1;j--){
  for(var i=totalRows-1;i>=1;i--){
     cell =  $("#tbl").find("tr").eq(i).find("td").eq(j);
     if(cell.attr("style")!=undefined){
          if(cell.attr("style")=="display:none"){
            cell.remove();
          }
     }
  }
}
}
    </script>


  </head>
 
  <body>
  <table id="tbl"  cellpadding="3" border=1>
  <thead>
     <tr>
        <td>销售时间</td>
      <td>裙子</td>
      <td>裤子</td>
      <td>风衣</td>
      <td>鞋子</td>
     </tr>
  </thead>
  <tbody>
  <tr>
  <td>8:00-9:00</td>
      <td>3</td>
      <td></td>
      <td>4</td>
      <td></td>
  </tr>
  <tr>
  <td>9:00-10:00</td>
      <td>3</td>
      <td>2</td>
      <td>5</td>
      <td>3</td>
  </tr>
  <tr>
  <td>10:00-11:00</td>
      <td>3</td>
      <td>2</td>
      <td></td>
      <td>1</td>
  </tr>
  <tr>
  <td>11:00-12:00</td>
      <td></td>
      <td></td>
      <td></td>
      <td>1</td>
  </tr>
  </tbody>
  </table>
  <input type="button" value="合并" onclick="merge2();">
  </body>
</html>
总结 :在使用remove的时候 ,一定要注意如果 从list的开始元素循环下去,remove掉一个元素后,有些元素就找不到了或者说不是要找的那个元素;最好是从后面开始循环。

免责声明:文章转载自《JQuery实现表格的相同单元格合并的三种方法》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇js 判断大小端存储nginx重定向下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

jQuery LigerUI 插件介绍及使用之ligerGrid

一,简介 ligerGrid的功能列表: 1,支持本地数据和服务器数据(配置data或者url) 2,支持排序和分页(包括Javascript排序和分页) 3,支持列的“显示/隐藏” 4,支持明细行(表格内嵌) 5,支持汇总行 6,支持单元格模板 7,支持编辑表格(ligerGrid的一个特色,需要其他表单插件的支持) 8,支持树表格(待加入) 8,支持分...

Angular引入第三方库

 原文已经写的很好了。原文链接: https://blog.csdn.net/yuzhiqiang_1993/article/details/71215232        加上2点给自己用,引入bootstrap样式,需要在angular-cli.json的styles中引入。        安装的类型描述文件@types/jquery在node_mod...

jquery 判断元素是否存在于数组中

要判断数组中是否包含某个元素,从原理来来说,就是遍历整个数组,然后判断是否相等 可以使用Jquery提供的方法: $.inArray("元素(字符串)",数组名称) 进行判断 ,当存在该元素(字符串)时,返回该元素在数组的下标,不存在时返回 -1 $(function () { var array = ["asp.net", "as...

jQuery(一)

一、什么是 jQuery jQuery 是 js 的一个库,封装了我们开发过程中常用的一些功能,方便我们调用,提高开发效率。 js库是把我们常用的功能放到一个单独的文件中,我们用的时候,直接引用到页面里即可。 关于jQuery的相关资料: 官网:http://jquery.com/ 官网API文档:http://api.jquery.com/ 汉化API...

基于JQuery的浮动DIV显示提示信息并自动隐藏

/*** 浮动DIV定时显示提示信息,如操作成功, 失败等* @param string tips (提示的内容)* @param int height 显示的信息距离浏览器顶部的高度* @param int time 显示的时间(按秒算), time > 0* @sample <a href="javascript:void(0);" onc...

jQuery时间轴插件timeline.js

http://www.jq22.com/jquery-info13695 http://www.jq22.com/jquery-info13357 简要教程 timeline.js是一款jQuery时间轴幻灯片插件。通过timeline.js插件,你可以很容易的制作出水平或垂直时间轴效果,并可以像幻灯片一样前后切换时间点。 使用方法 在页面中引入jquer...