一个JAVASCRIPT实用函数,完成合并表格中列中具有相同内容的列单元格的功能

代码如下:
/*****************************************
名称:MergeTableCell
功能:合并表格中特定列中具有相同内容的列单元格(向下合并)
参数:
TheTable:Table的ID(直接传ID即可,不用加其它父限定)
ColumnIndex:从零开始的要合并列的索引
******************************************/
function MergeTableCell(TheTable,ColumnIndex)
{
 
   var RowCount = TheTable.rows.length;
   var CurrentRow = null;
   var NextRow = null;
   var MergeTag = 0;
   var StartMergeCell = 0;
   var EndMergeCell = 0;
   var NextCell = null;
   var Iter = 0;
  
 
   for(var i=0;i<RowCount;i=Iter)
   {
      MergeTag = 0;
      StartMergeCell = 0;
      EndMergeCell = 0;
      CurrentRow = TheTable.rows(i);
      window.alert(CurrentRow.cells(ColumnIndex).innerText);
      if ((CurrentRow.cells(ColumnIndex) != null)&&(i != RowCount-1))
      {                  
         for(var j=i+1;j<RowCount;j++)
         {
            NextRow = TheTable.rows(j);
            NextCell = NextRow.cells(ColumnIndex);
            var strNext = new String();
            strNext = NextCell.innerText;
            var strCurr =new String();
            strCurr = CurrentRow.cells(ColumnIndex).innerText;
            if ( strNext !=  strCurr)
            {
              break;
            }
            else
            {
               if (j==i+1)
               {
                 StartMergeCell = j;
               }
               EndMergeCell = j;
               MergeTag++;
            }
             
         }
       
         if (MergeTag != 0)
         {
            CurrentRow.cells(ColumnIndex).rowSpan = MergeTag + 1;
            for(var k=StartMergeCell;k<=EndMergeCell;k++)
            {
               TheTable.rows(k).deleteCell(ColumnIndex);
            }
         }
      }
       Iter = Iter + MergeTag + 1 ;
 

   }
      
}


很烂的算法,希望大家不要介意!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值