日韩欧美国产精品免费一二-日韩欧美国产精品亚洲二区-日韩欧美国产精品专区-日韩欧美国产另-日韩欧美国产免费看-日韩欧美国产免费看清风阁

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

JS技巧:使用JavaScript將復雜表格導出為Excel

admin
2010年8月17日 21:54 本文熱度 3733
使用JavaScript將表格導出為Excel文件是一種比較常見的導出方法,但復雜表格的導出比較麻煩(比如報表的導出),為此我專門寫了一段代碼專門處理表格導出,與各位分享一下。

util.js:
/**
 * Utilities for exporting a table as an excel file
 * @author Daniel.Sun(山風小子)
 * @version 0.6
 */

var idTmr = "";
function Cleanup() {
    window.clearInterval(idTmr);
    CollectGarbage();
}

function exportAsXls(table) {

    function ImpactedCell(row, col, offset) {
        this.row = row;
        this.col = col;
        this.offset = offset;
    }

    function CurrentCell(row, col, text, colspan, rowspan) {
        this.row = row;
        this.col = col;
        this.text = text;
        this.colspan = colspan;
        this.rowspan = rowspan;

        this.getRow = function getRow() {
            return this.row;
        }

        this.setRow = function setRow(row) {
            this.row = row;
        }

        this.getCol = function getCol() {
            return this.col;
        }

        this.setCol = function setCol(col) {
            this.col = col;
        }

        this.setColspan = function setColspan(colspan) {
            this.colspan = colspan;
        }

        this.getColspan = function getColspan() {
            return this.colspan;
        }

        this.setRowspan = function setRowspan(rowspan) {
            this.rowspan = rowspan;
        }

        this.getRowspan = function getRowspan() {
            return this.rowspan;
        }
    }

    function CellManager(originalRow, colOffset, impactedCells, currentCell) {
        this.originalRow = originalRow;
        this.colOffset = colOffset;
        this.impactedCells = impactedCells;
        this.currentCell = currentCell;

        this.setCurrentCell = function setCurrentCell(currentCell) {
            this.currentCell = currentCell;
        }

        this.setOriginalRow = function setOriginalRow(originalRow) {
            this.originalRow = originalRow;
        }

        this.getCorrectedCol = function getCorrectedCol() {
            return this.currentCell.getCol() + this.colOffset;
        }

        this.setColOffset = function setColOffset(colOffset) {
            this.colOffset = colOffset;
        }

        this.getColOffset = function getColOffset() {
            return this.colOffset;
        }

        this.initColOffset = function initColOffset() {
            if (this.currentCell.getRow() != this.originalRow) {
                this.colOffset = 0;
            }
        }

        this.getImpactedCells = function getImpactedCells() {
            return this.impactedCells;
        }

        this.addImpactedCell = function addImpactedCell(impactedCell) {
            this.impactedCells.push(impactedCell);
        }

        this.addImpactedCells = function addImpactedCells() {
            var currentCell = this.currentCell;

            for (var i = 1; i < currentCell.getRowspan(); i++) {
                var impactedRow = currentCell.getRow() + i;
               
                this.calcOffset(impactedRow);

                var impactedCol = this.getCorrectedCol();

                var offset = 0;
                if (currentCell.getColspan()) {
                    offset = currentCell.getColspan();
                } else {
                    offset = 1;
                }

                this.addImpactedCell(new ImpactedCell(impactedRow, impactedCol, offset))
            }

        }

        this.calcOffset = function calcOffset(row) {

            var colOffset = this.colOffset;
            var result = colOffset;
           
            for (var i = 0; i < this.impactedCells.length; i++) {
                var impactedCell = this.impactedCells[i];

                if (row == impactedCell.row && this.getCorrectedCol() == impactedCell.col) {

                    colOffset += impactedCell.offset;
                   
                    result = colOffset;
                    break;
                }
            }

            this.colOffset = result;

            return result;
        }

        this.correctColOffset = function correctColOffset() {
            var currentCell = this.currentCell;

            var tmpColOffset;
            while (true) {
                this.calcOffset(currentCell.getRow());

                tmpColOffset = this.getColOffset();

                this.calcOffset(currentCell.getRow());

                if (this.getColOffset() == tmpColOffset) {
                     break;
                }
            }
        }

        this.mergeCells = function mergeCells(oSheet, row1, col1, row2, col2) {
            oSheet.Range(oSheet.Cells(row1, col1), oSheet.Cells(row2, col2)).MergeCells = true;
        }

        this.mergeCellsConditionally = function mergeCellsConditionally(oSheet) {
            var currentCell = this.currentCell;

            var colsShouldMerge = currentCell.getColspan() > 1;
            var rowsShouldMerge = currentCell.getRowspan() > 1;

            if (colsShouldMerge && !rowsShouldMerge) {
                this.mergeCells(
                    oSheet,
                    currentCell.getRow(), this.getCorrectedCol(),
                    currentCell.getRow(), this.getCorrectedCol()
                     + currentCell.getColspan() - 1
                );
            } else if (!colsShouldMerge && rowsShouldMerge) {
                this.mergeCells(
                    oSheet,
                    currentCell.getRow(), this.getCorrectedCol(),
                    currentCell.getRow() + currentCell.getRowspan() - 1, this.getCorrectedCol()
                );
            } else if (colsShouldMerge && rowsShouldMerge) {
                this.mergeCells(
                    oSheet,
                    currentCell.getRow(), this.getCorrectedCol(),
                    currentCell.getRow() + currentCell.getRowspan() - 1,
                        this.getCorrectedCol() + currentCell.getColspan() - 1
                );
            }
        }
    }

    var oXL = new ActiveXObject("Excel.Application");
    var oWB = oXL.Workbooks.Add();
    var oSheet = oWB.ActiveSheet;

    var cellManager = new CellManager(0, 0, new Array());

    traverseTable(
        table,
        function(i, j, cell) {
            var text = cell.innerText;
            if (null != text) {
                var row = i + 1;
                var col = j + 1;

                var currentCell = new CurrentCell(row, col, text);
                cellManager.setCurrentCell(currentCell);

                cellManager.initColOffset();

                cellManager.setOriginalRow(row);

                var colspan = cell.getAttribute("colspan");
                var rowspan = cell.getAttribute("rowspan");
               
                currentCell.setColspan(colspan);
                currentCell.setRowspan(rowspan);


                var colsShouldMerge = currentCell.getColspan() > 1;
                var rowsShouldMerge = currentCell.getRowspan() > 1;


                cellManager.correctColOffset();

                if (rowsShouldMerge) {
                    cellManager.addImpactedCells();
                }
               
                cellManager.mergeCellsConditionally(oSheet);
               
                var cellInSheet = oSheet.Cells(currentCell.getRow(), cellManager.getCorrectedCol());

                if (colsShouldMerge) {
                    var align = cell.getAttribute("align");
                    if ("center" == align) {
                        cellInSheet.HorizontalAlignment = 3;
                    }
                    
                    cellManager.setColOffset(cellManager.getColOffset() + (colspan - 1));

                }

                cellInSheet.NumberFormatLocal = "@";
                cellInSheet.value = text;
            }
        }
    )

    oXL.Visible = true;
    oXL.UserControl = true;

    oXL = null;
    idTmr = window.setInterval("Cleanup();",1);
}

function traverseTable(table, action) {
    for (var i = 0; i < table.rows.length; i++) {
        var row = table.rows(i);
        for (var j = 0; j < row.cells.length; j++) {
            var cell = row.cells(j);
            action(i, j, cell);
        }
    }
}測試代碼:


<script src="util.js"></script>
</head>

<body>
<table width="200" border="1" onclick="exportAsXls(this)">
  <tr>
    <td colspan="4" rowspan="2">1234678t</td>
    <td>5</td>
    <td>k</td>
    <td colspan="2">mr</td>
  </tr>
  <tr>
    <td>9</td>
    <td colspan="2" rowspan="3">wgbnpt</td>
    <td>z</td>
  </tr>
  <tr>
    <td rowspan="2">1013</td>
    <td colspan="2" rowspan="3">eh14151920</td>
    <td>11</td>
    <td>12</td>
    <td>c</td>
  </tr>
  <tr>
    <td>16</td>
    <td>17</td>
    <td>a</td>
  </tr>
  <tr>
    <td>18</td>
    <td colspan="5">2122dsj</td>
  </tr>
</table>
</body>
</html>

該文章在 2010/8/17 21:54:28 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 亚洲国产性夜夜综合 | 牛牛视频一区二区三区 | 国产一区二区三区高清视频 | 国产欧美va欧美va香蕉在 | 91看片淫黄大片在看 | 引领不用下载播放器的影视站 | 国产欧美日韩资源在线观看 | 欧美国产日韩1区俺去了 | 免费福利tv | 国产性爱在线观看 | 小说区图片区激情区视频区 | 国产一级在线现免费观看 | 国产永久精品一区二区污污 | 电影免费在线观看中文字幕 | 亚洲色精品vr一区二区三区 | 字幕乱码一二三四 | 天天人守人婷 | 日韩精品一区二区三区在线观看 | 日本一区二区三区在线观看入口 | 国产欧美日本韩国另类 | 大胸视频在线观看国产 | 欧美日韩一区二区三区在线播放 | 国产精品第44页 | 性感美女网站一区二区三区 | 免费国产黄线在线观看 | 亚洲日韩aⅴ在线视频 | 亚洲天天更新 | 成人试看120秒体验区 | 国产高清在线丝袜精品一区 | 久色资源免费的资源站 | 精品一卡二卡三卡四 | 99热这里只有精品免费播放 | 国产精品喷水 | 太大太长太粗太久太硬了 | 国产对白普通话视 | 国产精选在线视频 | 国产视频第一页bt天堂 | 亚洲欧美一区二区综合精品 | 1000部禁止18| 秋霞国产午夜 | 99re热视频在线|