4

我正在使用DataTables jquery 插件

我有一个带有 colspan 的多行表头的 DataTable。就像是:

<thead>
  <tr>
    <th>Level 1</th>
    <th colspan='2'>Level 1 - Item 1</th>
    <th colspan='2'>Level 1 - Item 2</th>
  </tr>
  <tr>
    <th>Level 2</th>
    <th>Level 2 - Item 1a</th>
    <th>Level 2 - Item 1b</th>
    <th>Level 2 - Item 2a</th>
    <th>Level 2 - Item 2b</th>
  </tr>
</thead>

但是,当我使用 TableTools 插件导出时,除了“打印”选项之外,其余所有(Excel、CSV、Pdf 等)只有“2 级”标题行而不是 1 级。

关于如何让它也导出 1 级的任何建议?

4

4 回答 4

2

如果您想将 level1 也导出到 excel,还有另一种方法:

将 rowspan/colspan 替换为空单元格,例如:

   <thead>
      <tr>
        <th>Level 1</th>
        <th>Level 1 - Item 1</th>
        <th></th>
        <th>Level 1 - Item 2</th>
        <th></th>
      </tr>
      <tr>
        <th>Level 2</th>
        <th>Level 2 - Item 1a</th>
        <th>Level 2 - Item 1b</th>
        <th>Level 2 - Item 2a</th>
        <th>Level 2 - Item 2b</th>
      </tr>
    </thead>

然后按照@misiu上面的建议,编辑 TableTools.js。
查找_fnGetDataTablesData并在其中更改:

if (oConfig.bHeader) { ... }

以此为:

if (oConfig.bHeader) {
    //another loop
    for (i = 0, rowCount = dt.nTHead.rows.length; i < rowCount; i++) {
        aRow = []; //clear row data
        for (j = 0, iLen = dt.aoColumns.length; j < iLen; j++) {
            if (aColumnsInc[j] && dt.nTHead.rows[i].children[j] !== null) {
                sLoopData = dt.nTHead.rows[i].children[j].innerHTML.replace(/\n/g, " ")
                    .replace(/<.*?>/g, "")
                    .replace(/^\s+|\s+$/g, "");
                sLoopData = this._fnHtmlDecode(sLoopData);
                aRow.push(this._fnBoundData(sLoopData, oConfig.sFieldBoundary, regex));
            } else {
                aRow.push(this._fnBoundData("", oConfig.sFieldBoundary, regex)); //I'm not shure of this!!
            }
        }
        aData.push(aRow.join(oConfig.sFieldSeperator));
    }
}

这会将复杂的标题复制/导出到 csv/excel。虽然空的表格单元格在 excel 中将保持为空并且不会被合并。您可以手动合并它们。

虽然不是一个理想的解决方案,但这对我来说非常有效。

于 2013-02-11T13:33:52.427 回答
1

编辑 TableTools.js。
查找_fnGetDataTablesData并在其中更改:

if (oConfig.bHeader) {
    aRow = [];

    for (i = 0, iLen = dt.aoColumns.length; i < iLen; i++) {
        if (aColumnsInc[i]) {
            sLoopData = dt.aoColumns[i].sTitle.replace(/\n/g, " ")
                .replace(/<.*?>/g, "")
                .replace(/^\s+|\s+$/g, "");
            sLoopData = this._fnHtmlDecode(sLoopData);

            aRow.push(this._fnBoundData(sLoopData, oConfig.sFieldBoundary, regex));
        }
    }

    aData.push(aRow.join(oConfig.sFieldSeperator));
}

对此:

if (oConfig.bHeader) {

    //another loop
    for (i = 0, rowCount = dt.nTHead.rows.length; i < rowCount; i++) {
        aRow = []; //clear row data
        for (j = 0, iLen = dt.aoColumns.length; j < iLen; j++) {
            if (aColumnsInc[j] && dt.nTHead.rows[i].children[j] !== null) {
                sLoopData = dt.nTHead.rows[i].children[j].innerHTML.replace(/\n/g, " ")
                    .replace(/<.*?>/g, "")
                    .replace(/^\s+|\s+$/g, "");
                sLoopData = this._fnHtmlDecode(sLoopData);
                aRow.push(this._fnBoundData(sLoopData, oConfig.sFieldBoundary, regex));
            } else {
                aRow.push(this._fnBoundData("", oConfig.sFieldBoundary, regex)); //I'm not shure of this!!
            }
        }
        aData.push(aRow.join(oConfig.sFieldSeperator));
    }
}

我现在无法测试这个 roght,所以试试这个。
当我从艾伦那里得到更好的解决方案时,我会更新我的答案。

于 2012-10-01T09:39:30.220 回答
0
if ( oConfig.bHeader )
    {
        //-1 because we don't want the last row header
        for (i=0; i<dt.nTHead.rows.length-1; i++)
        {
            //wrap jquery object
            $(dt.nTHead.rows[i]).find('th').each(function(){
           var th = $(this);
           sData += th.text().replace(/\n/g," ").replace( /<.*?>/g, "" ).replace(/^\s+|\s+$/g,"");

           var colspan = th.attr('colspan');
           if (!colspan) colspan = 1; //default colspan is 1

           //only the first colspan have the label, other colspans are empty text, we can't implement cell mergin in csv file
           for (j=0; j<colspan; j++)
           {
                 sData += oConfig.sFieldSeperator;
           }
        });

        sData += sNewline;
        }

        for ( i=0, iLen=dt.aoColumns.length ; i<iLen ; i++ )
        {
            if ( aColumnsInc[i] )
            {
                sLoopData = dt.aoColumns[i].sTitle.replace(/\n/g," ").replace( /<.*?>/g, "" ).replace(/^\s+|\s+$/g,"");
                sLoopData = this._fnHtmlDecode( sLoopData );

                sData += this._fnBoundData( sLoopData, oConfig.sFieldBoundary, regex ) +
                    oConfig.sFieldSeperator;
            }
        }
        sData = sData.slice( 0, oConfig.sFieldSeperator.length*-1 );
        sData += sNewline;
    }
于 2012-12-05T11:02:21.647 回答
0

看看这个答案https://datatables.net/forums/discussion/22592/export-multiple-row-headers 使用这段代码,您将能够从标题以及 colspan 和 rowspans 中导出所有单元格将在空单元格中转换:)

于 2014-12-31T16:50:18.367 回答