jsPDF-AutoTable:在页面上显示多个页脚,并排绘制多个水平表

时间:2019-02-15 07:10:13

标签: jquery jspdf jspdf-autotable

我用jsPDF-AutoTable创建了多个表,并排放置。这些表的内容根据我的HTML页面中的数据而有所不同。因此,同一页上可能并排有多个表。
面临的问题是为每对表创建页脚,以便页脚在每页上都重叠。
这是我的PDF文件的图像。
enter image description here

 const pdf = new jsPDF('l', 'pt',);
const totalPagesExp = '{total_pages_count_string}';
let first = null, last = null;

const footer = function (data) {
    var imgData = ''
    // HEADER
    pdf.setFontSize(20);
    pdf.setTextColor(40);
    pdf.setFontStyle('normal');

    if (imgData)
        pdf.addImage(imgData, 'JPEG', 400, 30, 60, 60);

    let str = 'Page ' + pdf.internal.getNumberOfPages();
    if (typeof pdf.putTotalPages === 'function')
        str = str + ' of ' + totalPagesExp;

    pdf.setFontSize(10);
    pdf.setFontStyle("normal");
    pdf.text(str, data.settings.margin.left + 470, pdf.internal.pageSize.height - 30);
    pdf.text('© 2019 mysite.com All Rights Reserved.', data.settings.margin.left, pdf.internal.pageSize.height - 30);
};

let y = 120;

$(".note").each(function () {
    const $frnt = $(this).find(".front");
    const $back = $(this).find(".back");
    y = pdf.autoTable.previous ? (first.finalY > last.finalY ? first.finalY + 25 : last.finalY + 25): y;

    pdf.autoTable({
        head: [[$frnt.find(".bk-title").text().trim().toString(), $frnt.find(".pgno").text().trim()]],
        body: [[{
            content: $back.find(".question").text().trim().toString(),
            colSpan: 2,
            styles: {halign: 'justify'}
        }]],
        startY: y,
        tableWidth: 200,
        styles: {
            cellWidth: 'wrap',
            valign: 'middle',
            font: 'times',
            fontSize: 12,
            overflow: 'linebreak'
        },
        headStyles: {
            fillColor: [247, 185, 7]
        },
        theme: 'striped',
        margin: {top: 150, right: 350},
        didDrawPage: footer
    });
    first = pdf.autoTable.previous;

    pdf.autoTable({
        head: [[$frnt.find(".bk-title").text().trim().toString(), $frnt.find(".pgno").text().trim()]],
        body: [[{content: $frnt.find(".title").text().trim().toString(), colSpan: 2, styles: {halign: 'justify'}}],
            [{content: $frnt.find(".desc").text().trim().toString(), colSpan: 2, styles: {halign: 'justify'}}]],
        startY: y,
        styles: {
            cellWidth: 'wrap',
            valign: 'middle',
            font: 'times',
            fontSize: 12,
            overflow: 'linebreak'
        },
        headStyles: {
            fillColor: [247, 185, 7]
        },
        theme: 'striped',
        margin: {top: 150, left: 340}
    });
    last = pdf.autoTable.previous;
    if (typeof pdf.putTotalPages === 'function')
        pdf.putTotalPages(totalPagesExp);
});


pdf.save(`${username}'s Notes.pdf`);

我该如何解决?

1 个答案:

答案 0 :(得分:0)

最后,我从here找到了解决方案。
在这里,表是动态添加的。当页面上有多个表时,将添加与每个表相对应的页脚。这就是页脚重叠的原因。基于上述解决方案,我将footer()函数的代码更改如下:

let currentpage = 0;

const footer = function (data) {
    if (currentpage < pdf.internal.getNumberOfPages()) {
        var imgData = ''
        // HEADER
        pdf.setFontSize(20);
        pdf.setTextColor(40);
        pdf.setFontStyle('normal');

        if (imgData)
            pdf.addImage(imgData, 'JPEG', 400, 30, 60, 60);

        let str = 'Page ' + pdf.internal.getNumberOfPages();
        if (typeof pdf.putTotalPages === 'function')
            str = str + ' of ' + totalPagesExp;

        pdf.setFontSize(10);
        pdf.setFontStyle("normal");
        pdf.text(str, data.settings.margin.left + 470, pdf.internal.pageSize.height - 30);
        pdf.text(`© ${new Date().getFullYear()} 3d-reader.com All Rights Reserved.`, data.settings.margin.left, pdf.internal.pageSize.height - 30);
        currentpage = pdf.internal.getNumberOfPages();
    }
};