zoukankan      html  css  js  c++  java
  • 合并表格

    <html> 
    <head> 
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
    <title>合并表格</title> 
    <script> 
    /////////////////////////////////////////////// 
    //功能:合并表格 
    //参数:tb-需要合并的表格ID 
    //参数:colLength--需要对前几列进行合并,比如, 
    //想合并前两列,后面的数据列忽略合并,colLength应为2 
    //缺省表示对全部列合并 
    //data:2011.11.06 
    /////////////////////////////////////////////// 
    function uniteTable(tb,colLength){ 
    //检查表格是否规整 
    if(!checkTable(tb)) return; 
    var i=0; 
    var j=0; 
    var rowCount=tb.rows.length; //行数 
    var colCount=tb.rows[0].cells.length; //列数 
    var obj1=null; 
    var obj2=null; 
    //为每个单元格命名 
    for(i=0;i<rowCount;i++){ 
    for(j=0;j<colCount;j++){ 
    tb.rows[i].cells[j].id="tb__" + i.toString() + "_" + j.toString(); 
    } 
    } 
    //逐列检查合并 
    for(i=0;i<colCount;i++){ 
    if(i==colLength) return; 
    obj1=document.getElementById("tb__0_"+i.toString()) 
    for(j=1;j<rowCount;j++){ 
    obj2=document.getElementById("tb__"+j.toString()+"_"+i.toString()); 
    if(obj1.innerText==obj2.innerText){ 
    obj1.rowSpan++; 
    obj2.parentNode.removeChild(obj2); 
    }else{ 
    obj1=document.getElementById("tb__"+j.toString()+"_"+i.toString()); 
    } 
    } 
    } 
    } 
    
    ///////////////////////////////////////// 
    //功能:检查表格是否规整 
    //参数:tb--需要检查的表格ID 
    //data: 2011.11.06
    ///////////////////////////////////////// 
    function checkTable(tb){ 
    if(tb.rows.length==0) return false; 
    if(tb.rows[0].cells.length==0) return false; 
    for(var i=0;i<tb.rows.length;i++){ 
    if(tb.rows[0].cells.length!=tb.rows[i].cells.length) return false; 
    } 
    return true; 
    } 
    </script> 
    </head> 
    <body> 
    <table width="400" border="1" id="table1"> 
    <tr> 
    <td>a</td> 
    <td>for</td> 
    <td>100</td> 
    <td>200</td>
    <td>1</td> 
    </tr> 
    <tr> 
    <td>a</td> 
    <td>for</td> 
    <td>100</td> 
    <td>300</td> 
    <td>2</td> 
    </tr> 
    <tr> 
    <td>a</td> 
    <td>if</td> 
    <td>100</td> 
    <td>200</td> 
    <td>3</td> 
    </tr> 
    <tr> 
    <td>a</td> 
    <td>if</td> 
    <td>300</td> 
    <td>300</td> 
    <td>4</td> 
    </tr> 
    <tr> 
    <td>a</td> 
    <td>if</td> 
    <td>320</td> 
    <td>300</td> 
    <td>5</td> 
    </tr> 
    </table> 
    <br><input type="button" value="合并表格" onClick="uniteTable(table1,4)"> 
    </body> 
    </html>
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> 
    <HTML> 
    <HEAD> 
    <TITLE> New Document </TITLE> 
    <META NAME="Generator" CONTENT="EditPlus"> 
    <META NAME="Author" CONTENT=""> 
    <META NAME="Keywords" CONTENT=""> 
    <META NAME="Description" CONTENT=""> 
    </HEAD> 
    <SCRIPT LANGUAGE="JavaScript"> 
    function autoRowSpan(tb,row,col) 
    { 
    var lastValue=""; 
    var value=""; 
    var pos=1; 
    for(var i=row;i<tb.rows.length;i++){ 
    value = tb.rows[i].cells[col].innerText; 
    if(lastValue == value){ 
    tb.rows[i].deleteCell(col); 
    tb.rows[i-pos].cells[col].rowSpan = tb.rows[i-pos].cells[col].rowSpan+1; 
    pos++; 
    }else{ 
    lastValue = value; 
    pos=1; 
    } 
    } 
    } 
    
    </SCRIPT> 
    <BODY onload="autoRowSpan(tb,0,0)"> 
    <TABLE id="tb" border="1"> 
    <THEAD> 
    <TR > 
    <TD>国家</TD> 
    <TD>地区</TD> 
    </TR> 
    </THEAD> 
    <TR> 
    <TD>中国</TD> 
    <TD>河南</TD> 
    </TR> 
    <TR> 
    <TD>中国</TD> 
    <TD>四川</TD> 
    </TR> 
    <TR> 
    <TD>中国</TD> 
    <TD>北京</TD> 
    </TR> 
    <TR> 
    <TD>美国</TD> 
    <TD>纽约</TD> 
    </TR> 
    <TR> 
    <TD>美国</TD> 
    <TD>洛杉矶</TD> 
    </TR> 
    <TR> 
    <TD>英国</TD> 
    <TD>伦敦</TD> 
    </TR> 
    </TABLE> 
    </BODY> 
    </HTML>
    //tbl:table对应的dom元素,
    //beginRow:从第几行开始合并(从0开始),
    //endRow:合并到哪一行,负数表示从底下数几行不合并
    //colIdxes:合并的列下标的数组,如[0,1]表示合并前两列,[0]表示只合并第一列
    function mergeSameCell(tbl,beginRow,endRow,colIdxes){
        var colIdx = colIdxes[0];
        var newColIdxes = colIdxes.concat();
        newColIdxes.splice(0,1)
        var delRows = new Array();
        var rs = tbl.rows;
        //endRow为0的时候合并到最后一行,小于0时表示最后有-endRow行不合并
        if(endRow === 0){
            endRow = rs.length - 1;
        }else if(endRow < 0){
            endRow = rs.length - 1 + endRow;
        }
        var rowSpan = 1; //要设置的rowSpan的值
        var rowIdx = beginRow; //要设置rowSpan的cell行下标
        var cellValue; //存储单元格里面的内容
        for(var i=beginRow; i<= endRow + 1; i++){
            if(i === endRow + 1){//过了最后一行的时候合并前面的单元格
                if(newColIdxes.length > 0){
                    mergeSameCell(tbl,rowIdx,endRow,newColIdxes);
                }
                rs[rowIdx].cells[colIdx].rowSpan = rowSpan;
            }else{
                var cell = rs[i].cells[colIdx];
                if(i === beginRow){//第一行的时候初始化各个参数
                    cellValue = cell.innerHTML;
                    rowSpan = 1;
                    rowIdx = i;
                }else if(cellValue != cell.innerHTML){//数据改变合并前面的单元格
                    cellValue = cell.innerHTML;
                    if(newColIdxes.length > 0){
                        mergeSameCell(tbl,rowIdx,i - 1,newColIdxes);
                    }
                    rs[rowIdx].cells[colIdx].rowSpan = rowSpan;
                    rowSpan = 1;
                    rowIdx = i;
                }else if(cellValue === cell.innerHTML){//数据和前面的数据重复的时候删除单元格
                    rowSpan++;
                    delRows.push(i);
                }
            }
        }
        for(var j=0;j<delRows.length; j++){
            rs[delRows[j]].deleteCell(colIdx);
        }
    }
    
    //调用
    mergeSameCell(document.getElementById('tableTbl'),1,-1,[0,1]);
  • 相关阅读:
    【poj1008】Maya Calendar
    【CodeVS4093】EZ的间谍网络
    2016.6.19 模拟考试
    【poj1129】Channel Allocation
    【poj2676】Sudoku
    Java 2D API
    Java 2D API
    IntelliJ IDEA
    IntelliJ IDEA 使用说明(For Eclipse user)
    IntelliJ IDEA
  • 原文地址:https://www.cnblogs.com/hnsongbiao/p/6389569.html
Copyright © 2011-2022 走看看