前端黑科技:一键将网页变 PDF,so easy!

boyanx3个月前技术教程11

在数字化办公时代,PDF以其跨平台、易于打印和分享等优点,成为了文档格式的首选。而今天,我们要学习一项超实用的前端黑科技,无需任何插件,就能将网页内容转化为PDF并下载,轻松提升工作效率!

告别繁琐,三步实现PDF导出

  1. 引入JS库: 使用 jsPDF 和 html2canvas 这两个强大的JavaScript库,为PDF生成提供支持。
   npm install jspdf html2canvas
  1. HTML代码: 创建一个按钮,用于触发PDF生成和下载功能。
   
   
  1. JavaScript代码: 编写 exportPDF 函数,利用 html2canvas 将HTML元素转换为 canvas,再使用 jsPDF 将 canvas 转换为 PDF 并下载。
   import jsPDF from 'jspdf';
   import html2canvas from 'html2canvas';

   export default {
     methods: {
       async exportPDF() {
         const element = document.getElementById('contentToConvert');
         const canvas = await html2canvas(element);
         const imgData = canvas.toDataURL('image/png');

         const pdf = new jsPDF({
           orientation: 'p', // 纵向
           unit: 'mm', // 单位
           format: 'a4' // 纸张大小
         });

         const imgWidth = 210; // A4纸宽度,单位mm
         const pageHeight = 297; // A4纸高度,单位mm
         let imgHeight = (canvas.height * imgWidth) / canvas.width;
         let position = 0;
         let pageData = '';

         // 处理多页情况
         if (imgHeight < pageheight pagedata='imgData;' else while imgheight> 0) {
             pdf.addImage(imgData, 'PNG', 0, position, imgWidth, imgHeight > pageHeight ? pageHeight : imgHeight);
             imgHeight -= pageHeight;
             position -= pageHeight;
             if (imgHeight > 0) {
               pdf.addPage();
             }
           }
         }
         // 添加图片到PDF
         pdf.addImage(pageData, 'PNG', 0, 0, imgWidth, imgHeight>pageHeight?pageHeight:imgHeight);
         // 保存PDF
         pdf.save('download.pdf');
       }
     }
   };

代码解析:

  1. 引入 jsPDF 和 html2canvas:
   import jsPDF from 'jspdf';
   import html2canvas from 'html2canvas';

这两行代码引入了 jsPDF 和 html2canvas 库,用于生成PDF和将HTML元素转换为 canvas。

  1. 获取目标元素:
   const element = document.getElementById('contentToConvert');

这行代码获取了ID为 contentToConvert 的HTML元素,也就是我们需要转换为PDF的内容。

  1. 将HTML元素转换为Canvas:
   const canvas = await html2canvas(element);

这行代码使用 html2canvas 将目标元素转换为 canvas 对象。

  1. 创建PDF对象:
   const pdf = new jsPDF({
       orientation: 'p', // 纵向
       unit: 'mm', // 单位
       format: 'a4' // 纸张大小
     });

这行代码创建了一个新的 jsPDF 对象,并设置了PDF的页面方向、单位和纸张大小。

  1. 计算图片尺寸和位置:
   const imgWidth = 210; // A4纸宽度,单位mm
   const pageHeight = 297; // A4纸高度,单位mm
   let imgHeight = (canvas.height * imgWidth) / canvas.width;
   let position = 0;
   let pageData = '';

这几行代码计算了要添加到PDF中的图片的宽度、高度和位置。

  1. 添加图片到PDF:
   pdf.addImage(pageData, 'PNG', 0, 0, imgWidth, imgHeight>pageHeight?pageHeight:imgHeight);

这行代码将图片添加到PDF文档中。

  1. 保存PDF文件:
   pdf.save('download.pdf');

这行代码将生成的PDF文件保存到本地,文件名为 download.pdf。

总结

通过以上步骤,我们就能轻松地将网页内容转换为PDF并下载。这项技术不仅可以用于生成各种报表和文档,还可以用于制作电子书、电子票据等,应用场景非常广泛,快来试试吧!

标签: pdfobject.js

相关文章

文档在线预览(三)使用前端实现word、excel、pdf、ppt 在线预览

文档在线预览(三)使用前端实现word、excel、pdf、ppt 在线预览

关于实现文档在线预览的做法,之前文章提到了的两种实现方式:1、通过将文档转成图片:详见《文档在线预览(一)通过将txt、word、pdf转成图片实现在线预览功能》;2、将文档转成html:详见《文档在...

硕士博士福音:超好用的7大PDF工具汇总

作为硕士博士,日常工作之一就是阅读文献。PDF文件作为文献的载体,和大家的关系也是抬头不见低头见。我们都知道PDF文件的优势明显,能够避免格式错乱以及文件被误改,但不如Word文档修改得顺畅。在日常科...

【分享】教你如何使用 Java 读取 Excel、docx、pdf 和 txt 文件

在 Java 开发中,我们经常需要读取不同类型的文件,包括 Excel 表格文件、"doc" 和 "docx" 文档文件、PDF 文件以及纯文本文件。其中最常用的是 Apache POI 库。Apac...

php生成pdf电子签名

要在 PHP 中生成带有签名的 PDF 文件,可以使用一些流行的库,如 **TCPDF** 或 **FPDF**。以下是使用 **TCPDF** 库生成带有签名的 PDF 的步骤和示例代码。### 步...

PDF文件处理:PDFPlumberLoader 对象和 PyPDFLoader对象

pdfplumber包中的 PDFPlumberLoader 对象和 langchain_community 包中的 PyPDFLoader 对象都用于加载和处理 PDF 文档,但它们有不同的实现和功...

word文档怎么插入pdf?一文详解,建议收藏!

在工作中我们可能会有在word文档中插入pdf文件的需求,这篇文章就跟大家分享一下解决办法。第1步:打开word文档,在【插入】选项卡下的【文本】功能组中单击【对象】按钮。第2步:在打开的【对象】对话...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。