javascript – 如何使用jsPDF和HTML2Canvas拥有多个pdf页面

前端之家收集整理的这篇文章主要介绍了javascript – 如何使用jsPDF和HTML2Canvas拥有多个pdf页面前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个脚本使用 HTML2Canvas在页面截取div的截图,然后使用jsPDF将其转换为pdf.

问题是生成的pdf只有一页,在某些情况下屏幕截图需要多个页面.例如,屏幕截图大于8.5×11.宽度很好,但我需要它来创建多个页面以适应整个屏幕截图.

这是我的脚本:

var pdf = new jsPDF('portrait','pt','letter');
$('.export').click(function() {
      pdf.addHTML($('.profile-expand')[0],function () {
           pdf.save('bfc-schedule.pdf');
      });
 });

有什么想法我可以修改它以允许多个页面

解决方法

pdf.addHtml doesnot work if there are svg images on the web page..
I copy the solution here: // suppose your picture is already in a canvas var imgData = canvas.toDataURL(‘image/png’); /* Here are the numbers (paper width and height) that I found to work. It still creates a little overlap part between the pages,but good enough for me. if you can find an official number from jsPDF,use them. */

var imgWidth = 210; 
var pageHeight = 295;  
var imgHeight = canvas.height * imgWidth / canvas.width;
var heightLeft = imgHeight;
var doc = new jsPDF('p','mm');
var position = 0;

doc.addImage(imgData,'PNG',position,imgWidth,imgHeight);
heightLeft -= pageHeight;

while (heightLeft >= 0) {
  position = heightLeft - imgHeight;
  doc.addPage();
  doc.addImage(imgData,imgHeight);
  heightLeft -= pageHeight;
}
doc.save( 'file.pdf');`
原文链接:https://www.f2er.com/js/150336.html

猜你在找的JavaScript相关文章