pdfMake - 宽表分页符

Jef*_*rey 7 pdfmake

我正在使用 pdfMake 生成表格报告。一些报告非常宽,不适合标准页面宽度,即使在横向模式下也是如此。目前,当表格内容溢出页边距时,pdfMake 会切断表格内容。

当表格太宽时,我想分页,就像行溢出到下一页一样。

这可以使用pdfMake吗?

可以使用 pageBreakBefore 回调函数对此有所帮助吗?

谢谢

小智 3

是的,这可以通过 实现pdfMake,尽管目前还不是一项功能。

要实现这一点,您只需将溢出的列分解到另一个表中即可。我们可以将所有表放在一个数组中,然后将它们设置如下docDefinition。可以在模板构造函数中定义表中所需的任何公共属性。

for (var i = 0; i < tables.length;i++) {
    docDefinition.content[i] = new Template();  
    docDefinition.content[i].table.body  = tables[i];
    docDefinition.content[i].table.widths = widths[i];
    if (i > 0) {
        docDefinition.content[i].pageBreak = 'before';
    }
}

function Template(){
    this.table = {
            dontBreakRows: true
    };
    //zebra stripes layout
    this.layout = {
            fillColor: function (row, node, col) {
                return (row % 2 === 0) ? '#CCCCCC' : null;
            }
    }
}
Run Code Online (Sandbox Code Playgroud)

我们如何判断一列是否会溢出?我们有两个选择:

  1. 如果您使用 bootstrap 数据表,则可以在 html 中使用“width”属性。
  2. pdfmake 计算实际宽度,但您可能需要在 .pdf 中进行挖掘pdfmake.js

然后,循环遍历,添加宽度,直到超出限制(我的限制是 8pt 字体)。您可以对 TH 执行此操作,然后保存这些列拆分并将其用于 TD。

如果最终页面刚刚溢出,我们不希望最终页面只有一栏,我们希望每个页面具有大致相同的宽度。我们计算所需的页数,然后从那里找到所需的断点。为了更轻松地将页面链接在一起,您可以在每个表的开头添加行号列。

var colSplits = [];
var tables = new Array();

function parseTHs(colSplits, tables) {
    var colSum = 0;
    var pageSize = 1120-7*rows.toString().length;
    var paddingDiff = 11.9;
    var columns = 0;
    var prevSum;
    var i = 0;
    var width = $(".dataTables_scrollHeadInner > table").width();
    var pages = Math.ceil(width/pageSize);
    console.log("pages: "+pages);
    var desiredBreakPoint = width/pages;
    console.log("spread: "+desiredBreakPoint);
    var limit = pageSize;
    var row = ['#'];
    var percent = '%';
    widths.push(percent);
    $(".dataTables_scrollHeadInner > table > thead > tr:first > th").each(function() {          
        prevSum = colSum;
        colSum += $(this).outerWidth()-paddingDiff;
        //if adding column brings us farther away from the desiredBreakPoint than before, kick it to next table
        if (colSum > limit || desiredBreakPoint-colSum > desiredBreakPoint-prevSum) {
            tables[i] = [row];
            row = ['#'];
            widths.push(percent);
            colSplits.push(columns);
            i++;
            desiredBreakPoint += width/pages;
            limit = prevSum+pageSize;
        }
        row.push({text: $(this).text(), style:'header'});
        widths.push(percent);
        columns++;
    });
    //add the final set of columns
    tables[i] = [row];
}

function parseTDs(colSplits, tables) {
    var currentRow = 0;
    $("#"+tableId+" > tbody > tr").each(function() {
        var i = 0;
        var row = [currentRow+1];
        var currentColumn = 0;
        var split = colSplits[i];
        $(this).find("td").each(function() {
            if (currentColumn === split) {
                tables[i].push(row);
                row = [currentRow+1];
                i++;
                split = colSplits[i];
            }
            row.push({text: $(this).text()});
            currentColumn++;
        });
        //add the final set of columns
        tables[i].push(row);
        currentRow++;
    });
}

parseTHs(colSplits, tables);
parseTDs(colSplits, tables);
Run Code Online (Sandbox Code Playgroud)

注意:如果您希望这些列填充所有可用页面,可以在此链接中找到一个很好的实现。

我刚刚为宽度添加了 '%' 并将该代码添加到pdfmake.js.

希望这可以帮助!