jsPDF-AutoTable:在页面上显示多个页脚,并排绘制多个水平表格
jsPDF-AutoTable: Showing multiple footers on page with more than one horizontal tables drawn side by side
我用 jsPDF-AutoTable 创建了多个 table,并排放置。这些 table 内容因我的 HTML 页面中的数据而异。因此,同一页上可能并排存在多个 table。
我面临的问题是 为每对 table 创建页脚,这样页脚就会在每一页上重叠。
这是我的 PDF 文件的图像。
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`);
我该如何解决这个问题?
最后,我从here找到了解决方案。
这里 tables 是动态添加的。当页面上有多个 table 时,页脚会添加对应于每个 table。这就是页脚重叠的原因。基于上述解决方案,我将 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();
}
};
我用 jsPDF-AutoTable 创建了多个 table,并排放置。这些 table 内容因我的 HTML 页面中的数据而异。因此,同一页上可能并排存在多个 table。
我面临的问题是 为每对 table 创建页脚,这样页脚就会在每一页上重叠。
这是我的 PDF 文件的图像。
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`);
我该如何解决这个问题?
最后,我从here找到了解决方案。
这里 tables 是动态添加的。当页面上有多个 table 时,页脚会添加对应于每个 table。这就是页脚重叠的原因。基于上述解决方案,我将 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();
}
};